1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178
|
#! /bin/env perl
# ============================================================================
# $Id: snmpset.pl,v 6.0 2009/09/09 15:05:33 dtown Rel $
# Copyright (c) 2000-2009 David M. Town <dtown@cpan.org>
# All rights reserved.
# This program is free software; you may redistribute it and/or modify it
# under the same terms as the Perl 5 programming language system itself.
# ============================================================================
use strict;
use warnings;
use Net::SNMP 6.0 qw( :asn1 snmp_type_ntop DEBUG_ALL );
use Getopt::Std;
our $SCRIPT = 'snmpset';
our $VERSION = 'v6.0.0';
our %OPTS;
# 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 information?
if (@ARGV < 4) {
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{P}) ? (-protocol => $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) {
abort($e);
}
# Convert the ASN.1 types to the respresentation expected by Net::SNMP.
if (convert_asn1_types(\@ARGV)) {
usage();
}
my @args = (
exists($OPTS{E}) ? (-contextengineid => $OPTS{E}) : (),
exists($OPTS{n}) ? (-contextname => $OPTS{n}) : (),
-varbindlist => \@ARGV,
);
# Send the SNMP message.
if (!defined $s->set_request(@args)) {
abort($s->error());
}
# Print the results.
for ($s->var_bind_names()) {
printf "%s = %s: %s\n",
$_,
snmp_type_ntop($s->var_bind_types()->{$_}),
$s->var_bind_list()->{$_};
}
# Close the session.
$s->close();
exit 0;
# [functions] ----------------------------------------------------------------
sub convert_asn1_types
{
my ($argv) = @_;
# Mapping table: { "user input character" => constant byte value }
my %asn1_types = (
'a' => IPADDRESS,
'c' => COUNTER32,
'C' => COUNTER64,
'g' => GAUGE32,
'h' => OCTET_STRING,
'i' => INTEGER32,
'o' => OBJECT_IDENTIFIER,
'p' => OPAQUE,
's' => OCTET_STRING,
't' => TIMETICKS,
);
# Expect [OBJECT IDENTIFIER, ASN.1 type, object value] combination.
if ((ref($argv) ne 'ARRAY') || (scalar(@{$argv}) % 3)) {
return 1;
}
for (my $i = 0; $i < scalar @{$argv}; $i += 3) {
if (exists $asn1_types{$argv->[$i+1]}) {
if ($argv->[$i+1] eq 'h') {
if ($argv->[$i+2] =~ m/^(?:0x)?([A-F\d]+)$/i) {
# Convert hexadecimal string.
$argv->[$i+2] = pack 'H*', length($1) % 2 ? '0'.$1 : $1;
} else {
abort(sprintf q{The string "%s" is is expected in } .
q{hexadecimal format for type 'h'},
$argv->[$i+2]);
}
}
$argv->[$i+1] = $asn1_types{$argv->[$i+1]};
} else {
abort(sprintf 'The ASN.1 type "%s" is unknown', $argv->[$i+1]);
}
}
return 0;
}
sub abort
{
printf "$SCRIPT: " . ((@_ > 1) ? shift(@_) : '%s') . ".\n", @_;
exit 1;
}
sub usage
{
print << "USAGE";
$SCRIPT $VERSION
Copyright (c) 2000-2009 David M. Town. All rights reserved.
Usage: $SCRIPT [options] <hostname> <oid> <type> <value> [...]
Options: -v 1|2c|3 SNMP version
-d Enable debugging
SNMPv1/SNMPv2c:
-c <community> Community name
SNMPv3:
-u <username> Username (required)
-E <engineid> Context Engine ID
-n <name> Context Name
-a <authproto> Authentication protocol <md5|sha>
-A <password> Authentication password
-x <privproto> Privacy protocol <des|3des|aes>
-X <password> Privacy password
Transport Layer:
-D <domain> Domain <udp|udp6|tcp|tcp6>
-m <octets> Maximum message size
-p <port> Destination port
-r <attempts> Number of retries
-t <secs> Timeout period
Valid type values:
a - IpAddress i - INTEGER
c - Counter o - OBJECT IDENTIFIER
C - Counter64 p - Opaque
g - Gauge/Unsigned32 s - OCTET STRING
h - OCTET STRING (hex) t - TimeTicks
USAGE
exit 1;
}
# ============================================================================
|