Add support for Juniper SSL VPN appliances in L7::Neoteris

This commit is contained in:
Eric A. Miller
2012-07-31 19:44:24 -04:00
parent 912ba274a6
commit 225e12e979
5 changed files with 184 additions and 2 deletions

View File

@@ -5,8 +5,9 @@ version 2.09
[NEW FEATURES] [NEW FEATURES]
* Support for Avaya Secure Routers in new class L3::Tasman * Support for Avaya Secure Routers in new class L3::Tasman
* [3381027] Support for Cisco Nexus in new class L3::Nexus
* Add EDP and LLDP L2 Topology to L3::Extreme * Add EDP and LLDP L2 Topology to L3::Extreme
* [3185393] Support for Juniper SSL VPN in new class L7::Neoteris
* [3381027] Support for Cisco Nexus in new class L3::Nexus
* [1424336] Support for Extreme Discovery Protocol (EDP) * [1424336] Support for Extreme Discovery Protocol (EDP)
[ENHANCEMENTS] [ENHANCEMENTS]

View File

@@ -827,6 +827,12 @@ SNMP Interface to 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::Neoteris
SNMP Interface to Juniper SSL VPN appliances
See documentation in L<SNMP::Info::Layer7::Neoteris> for details.
=back =back
=back =back
@@ -1323,6 +1329,7 @@ sub device_type {
my %l7sysoidmap = ( my %l7sysoidmap = (
318 => 'SNMP::Info::Layer7::APC', 318 => 'SNMP::Info::Layer7::APC',
12532 => 'SNMP::Info::Layer7::Neoteris',
); );
# Get just the enterprise number for generic mapping # Get just the enterprise number for generic mapping

View File

@@ -65,6 +65,10 @@ sub model {
my $l7 = shift; my $l7 = shift;
my $id = $l7->id(); my $id = $l7->id();
my $model = &SNMP::translateObj($id); my $model = &SNMP::translateObj($id);
# Neoteris (Juniper IVE)
$model =~ s/^ive//i;
return $model; return $model;
} }
@@ -206,7 +210,6 @@ Cross references $l7->id() with product IDs.
Tries to discover the vendor by looking up the enterprise number in Tries to discover the vendor by looking up the enterprise number in
C<sysObjectID>. C<sysObjectID>.
=back =back
=head2 Global Methods imported from SNMP::Info =head2 Global Methods imported from SNMP::Info
@@ -226,6 +229,12 @@ to a hash.
Returns reference to the map between IID and physical Port. Returns reference to the map between IID and physical Port.
=item $l7->i_ignore()
Returns reference to hash. Increments value of IID if port is to be ignored.
Ignores loopback, other, and cpu
=back =back
=head2 Table Methods imported from SNMP::Info =head2 Table Methods imported from SNMP::Info

164
Info/Layer7/Neoteris.pm Normal file
View File

@@ -0,0 +1,164 @@
# SNMP::Info::Layer7::Neoteris
#
# Copyright (c) 2012 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::Layer7::Neoteris;
use strict;
use Exporter;
use SNMP::Info::Layer7;
@SNMP::Info::Layer7::Neoteris::ISA = qw/SNMP::Info::Layer7 Exporter/;
@SNMP::Info::Layer7::Neoteris::EXPORT_OK = qw//;
use vars qw/$VERSION %GLOBALS %MIBS %FUNCS %MUNGE/;
$VERSION = '2.09';
%MIBS = (
%SNMP::Info::Layer7::MIBS,
'UCD-SNMP-MIB' => 'versionTag',
'JUNIPER-IVE-MIB' => 'productVersion',
);
%GLOBALS = (
%SNMP::Info::Layer7::GLOBALS,
'os_ver' => 'productVersion',
'cpu' => 'iveCpuUtil',
);
%FUNCS = ( %SNMP::Info::Layer7::FUNCS, );
%MUNGE = ( %SNMP::Info::Layer7::MUNGE, );
sub vendor {
return 'juniper';
}
sub os {
return 'ive';
}
sub serial {
return '';
}
1;
__END__
=head1 NAME
SNMP::Info::Layer3::Neoteris - SNMP Interface to Juniper SSL VPN appliances
=head1 AUTHORS
Eric Miller
=head1 SYNOPSIS
# Let SNMP::Info determine the correct subclass for you.
my $neoteris = new SNMP::Info(
AutoSpecify => 1,
Debug => 1,
DestHost => 'myrouter',
Community => 'public',
Version => 2
)
or die "Can't connect to DestHost.\n";
my $class = $neoteris->class();
print "SNMP::Info determined this device to fall under subclass : $class\n";
=head1 DESCRIPTION
Subclass for Juniper SSL VPN appliances
=head2 Inherited Classes
=over
=item SNMP::Info::Layer7
=back
=head2 Required MIBs
=over
=item F<UCD-SNMP-MIB>
=item F<JUNIPER-IVE-MIB>
=item Inherited Classes' MIBs
See L<SNMP::Info::Layer7> for its own MIB requirements.
=back
=head1 GLOBALS
These are methods that return scalar value from SNMP
=over
=item $neoteris->vendor()
Returns 'juniper'.
=item $neoteris->os()
Returns 'ive'.
=item $neoteris->os_ver()
C<productVersion>
=item $neoteris->cpu()
C<iveCpuUtil>
=item $neoteris->serial()
Returns ''.
=back
=head2 Globals imported from SNMP::Info::Layer7
See documentation in L<SNMP::Info::Layer7> for details.
=head1 TABLE ENTRIES
These are methods that return tables of information in the form of a reference
to a hash.
=head2 Table Methods imported from SNMP::Info::Layer7
See documentation in L<SNMP::Info::Layer7> for details.
=cut

View File

@@ -86,6 +86,7 @@ Info/Layer3/Tasman.pm
Info/Layer3/Timetra.pm Info/Layer3/Timetra.pm
Info/Layer7.pm Info/Layer7.pm
Info/Layer7/APC.pm Info/Layer7/APC.pm
Info/Layer7/Neoteris.pm
Info/LLDP.pm Info/LLDP.pm
Info/MAU.pm Info/MAU.pm
Info/NortelStack.pm Info/NortelStack.pm