#! /usr/local/bin/perl eval '(exit $?0)' && eval 'exec /usr/local/bin/perl $0 ${1+"$@"}' && eval 'exec /usr/local/bin/perl $0 $argv:q' if 0; # ============================================================================ # $Id: snmpwalk.pl,v 2.5 2005/07/20 13:53:07 dtown Rel $ # Copyright (c) 2000-2005 David M. Town # All rights reserved. # This program is free software; you may redistribute it and/or modify it # under the same terms as Perl itself. # ============================================================================ use Net::SNMP v5.1.0 qw(:snmp DEBUG_ALL); use Getopt::Std; use strict; use vars qw($SCRIPT $VERSION %OPTS); $SCRIPT = 'snmpwalk'; $VERSION = '2.3.0'; # Validate the command line options if (!getopts('a:A:c:dD:E:m:n:p:r:t:u:v:x:X:', \%OPTS)) { _usage(); } # Do we have enough/too much information? if (@ARGV != 2) { if (@ARGV == 1) { push(@ARGV, '1.3.6.1.2.1'); # mib-2 } else { _usage(); } } # Create the SNMP session my ($s, $e) = Net::SNMP->session( -hostname => shift, exists($OPTS{a}) ? (-authprotocol => $OPTS{a}) : (), exists($OPTS{A}) ? (-authpassword => $OPTS{A}) : (), exists($OPTS{c}) ? (-community => $OPTS{c}) : (), exists($OPTS{D}) ? (-domain => $OPTS{D}) : (), exists($OPTS{d}) ? (-debug => DEBUG_ALL) : (), exists($OPTS{m}) ? (-maxmsgsize => $OPTS{m}) : (), exists($OPTS{p}) ? (-port => $OPTS{p}) : (), exists($OPTS{r}) ? (-retries => $OPTS{r}) : (), exists($OPTS{t}) ? (-timeout => $OPTS{t}) : (), exists($OPTS{u}) ? (-username => $OPTS{u}) : (), exists($OPTS{v}) ? (-version => $OPTS{v}) : (), exists($OPTS{x}) ? (-privprotocol => $OPTS{x}) : (), exists($OPTS{X}) ? (-privpassword => $OPTS{X}) : () ); # Was the session created? if (!defined($s)) { _exit($e); } # Perform repeated get-next-requests or get-bulk-requests (SNMPv2c) # until the last returned OBJECT IDENTIFIER is no longer a child of # OBJECT IDENTIFIER passed in on the command line. my @args = ( exists($OPTS{E}) ? (-contextengineid => $OPTS{E}) : (), exists($OPTS{n}) ? (-contextname => $OPTS{n}) : (), -varbindlist => [$ARGV[0]] ); if ($s->version == SNMP_VERSION_1) { my $oid; while (defined($s->get_next_request(@args))) { $oid = ($s->var_bind_names())[0]; if (!oid_base_match($ARGV[0], $oid)) { last; } printf( "%s = %s: %s\n", $oid, snmp_type_ntop($s->var_bind_types()->{$oid}), $s->var_bind_list()->{$oid}, ); @args = (-varbindlist => [$oid]); } } else { push(@args, -maxrepetitions => 25); outer: while (defined($s->get_bulk_request(@args))) { my @oids = oid_lex_sort(keys(%{$s->var_bind_list()})); foreach (@oids) { if (!oid_base_match($ARGV[0], $_)) { last outer; } printf( "%s = %s: %s\n", $_, snmp_type_ntop($s->var_bind_types()->{$_}), $s->var_bind_list()->{$_}, ); # Make sure we have not hit the end of the MIB if ($s->var_bind_list()->{$_} eq 'endOfMibView') { last outer; } } # Get the last OBJECT IDENTIFIER in the returned list @args = (-maxrepetitions => 25, -varbindlist => [pop(@oids)]); } } # Let the user know about any errors if ($s->error() ne '') { _exit($s->error()); } # Close the session $s->close(); exit 0; # [private] ------------------------------------------------------------------ sub _exit { printf join('', sprintf("%s: ", $SCRIPT), shift(@_), ".\n"), @_; exit 1; } sub _usage { print << "USAGE"; $SCRIPT v$VERSION Usage: $SCRIPT [options] [oid] Options: -v 1|2c|3 SNMP version -d Enable debugging SNMPv1/SNMPv2c: -c Community name SNMPv3: -u Username (required) -E Context Engine ID -n Context Name -a Authentication protocol -A Authentication password -x Privacy protocol -X Privacy password Transport Layer: -D Domain -m Maximum message size -p Destination port -r Number of retries -t Timeout period USAGE exit 1; } # ============================================================================