File: README

package info (click to toggle)
libsnmp-ruby 1.0.2-1
  • links: PTS, VCS
  • area: main
  • in suites: lenny, squeeze, wheezy
  • size: 1,420 kB
  • ctags: 581
  • sloc: ruby: 3,817; makefile: 41
file content (246 lines) | stat: -rw-r--r-- 7,947 bytes parent folder | download
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
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
= SNMP Library for Ruby

== Summary

This library implements SNMP (the Simple Network Management Protocol).  It is
implemented in pure Ruby, so there are no dependencies on external libraries
like net-snmp[http://www.net-snmp.org/].  You can run this library anywhere
that Ruby can run.

See snmplib.rubyforge.org[http://snmplib.rubyforge.org/] for more info.

Version 1.0.2 of this software supports the following:

* The GetRequest, GetNextRequest, GetBulkRequest, SetRequest, Response
  SNMPv1_Trap, SNMPv2_Trap, and Inform PDUs
* All of the ASN.1 data types defined by SNMPv1 and SNMPv2c
* Sending informs and v1 and v2 traps
* Trap handling for informs and v1 and v2 traps
* Symbolic OID values (ie. "ifTable" instead of "1.3.6.1.2.1.2.2") as   
  parameters to the SNMP.Manager API
* Includes symbol data files for all current IETF MIBs
* Compatibility with both Ruby 1.8 and Ruby 1.9 

See the SNMP.Manager, SNMP.TrapListener, and SNMP.MIB classes and the
examples below for more details.

== Changes

Changes for version 1.0.2:

* Internal code changes to make this library compatible with both Ruby 1.8
  and Ruby 1.9.  Note that an ord() method is now added to the Fixnum class
  for Ruby 1.8.  See the ber.rb file for details.

Changes for version 1.0.1:

* Made the host configurable for the TrapListener.  Previously defaulted
  to 'localhost'.

Changes for version 1.0.0:

* Added to_s method to TimeTicks.  Displays time in human-readable form
  instead of just a number.  The to_i method can still be used to get the
  number of ticks.

Changes for version 0.6.1:

* Made decoding of unsigned integers more liberal, so that they are  
  interpreted as positive integers even if the high bit is set.
* Added support for receiving InformRequest PDUs from the TrapListener class.

Changes for version 0.6.0:

* Added support for sending informs and traps for SNMPv2c and traps for
  SNMPv1
* Improved SNMP::Manager#walk so that it can handle missing varbinds
  when reading tables.  The indexes for a table row read by #walk are now
  guaranteed to match. 
* Added to_oid methods to SNMP::OctetString, SNMP::Integer, and
  SNMP::IpAddress (feature request #2486)
* Fixed some problems with retrying requests that caused annoying "Request ID
  mismatch" warnings and caused too few retries to be attempted
* Thanks to Mark Cotner, Dan Hamlin, Tim Howe, Diana Eichert, Ery Lee,
  Jan ge Johnsen, and Jeff Foster for their help and suggestions (and
  apologies in advance if I have forgotten someone).

Changes for version 0.5.1:

* Fixed bugs #2054 and #2164.  Responses were ignored if they did
  not come back from the same host that the request was sent to.  This
  behavior causes problems for some multi-homed hosts.
* Fixed bugs #1679 (NameError in Manager.get_response()) and #1736 
  (Notifications not included in YAML output).
* Added Manager.get_value convenience method to get a list of values for a 
  list of OIDs instead of the full VarBindList list like Manager.get.
* Added vb_list alias for PDU.varbind_list.
* Changed how Manager.walk yields to it's block.  It is now more consistent 
  about yielding a list if a list is provided as an argument.
* Break out of Manager.walk instead of looping forever if OIDs returned by the 
  remote host are not in ascending order.

Changes for version 0.4.0:

* Added support for loading MIBs and using symbolic OID values.
* Enhanced Manager.walk
    * It can now take an OID list as a parameter.  (Thanks to Simon
      Barnes for the suggestion.)
    * Takes a block instead of returning a list to allow incremental
      processing of results.
* Some minor improvements to code structure and error messages.

Changes for version 0.3.0:

* Added SNMPv1_Trap and SNMPv2_Trap classes
* Added TrapListener class for receiving v1 and v2 traps
* Added Manager.walk
* Fixed a problem with IpAddress encoding
* Defined IpAddress.== and IpAddress.eql? so that IpAddress objects can be
  compared by value

Changes for version 0.2.0:

* Added GetBulkRequest
* Added open and close methods to the Manager class to ensure that
  sockets can be properly released.
* Made SNMP::OctetString and SNMP::Integer behave more like Ruby's String and 
  Fixnum
* Fixed a problem with encoding/decoding the object id "0.0"

== Installation

You can use RubyGems [http://rubyforge.org/projects/rubygems] to
install the latest version of the SNMP library remotely.

  gem install --remote snmp

The SNMP Library can be downloaded from
RubyForge[http://rubyforge.org/projects/snmplib/] in several different
formats.

From the .gem file you can install using
RubyGems[http://rubyforge.org/projects/rubygems].

  gem install snmp-1.0.2.gem

From the .tgz or .zip file you can install using
setup.rb[http://i.loveruby.net/en/prog/setup.html].  Uncompress the archive
and then run setup.

  cd snmp-1.0.2
  ruby setup.rb (may require root privilege)  

== Testing

This library has received limited testing:
* The unit tests have been executed with both Ruby 1.8.6 and Ruby 1.9.0 on
  Mac OS X 10.5.
* Basic interoperability testing has been done with the
  net-snmp[http://www.net-snmp.org/] tools.

I'm very interested in hearing about successes or failures on other platforms.

Send me an email at hallidave at gmail.com.

== Examples

=== Get Request

Retrieve a system description.

  require 'snmp'
  
  SNMP::Manager.open(:Host => 'localhost') do |manager|
      response = manager.get(["sysDescr.0", "sysName.0"])
      response.each_varbind do |vb|
          puts "#{vb.name.to_s}  #{vb.value.to_s}  #{vb.value.asn1_type}"
      end
  end

=== Set Request

Create a varbind for setting the system name.

  require 'snmp'
  include SNMP

  manager = Manager.new(:Host => 'localhost')
  varbind = VarBind.new("1.3.6.1.2.1.1.5.0", OctetString.new("My System Name"))
  manager.set(varbind)
  manager.close

=== Table Walk

Walk the ifTable.

  require 'snmp'

  ifTable_columns = ["ifIndex", "ifDescr", "ifInOctets", "ifOutOctets"]
  SNMP::Manager.open(:Host => 'localhost') do |manager|
      manager.walk(ifTable_columns) do |row|
          row.each { |vb| print "\t#{vb.value}" }
          puts
      end
  end

=== Get-Next Request

A more difficult way to walk the ifTable.
 
  require 'snmp'
  include SNMP

  Manager.open(:Host => 'localhost') do |manager|
      ifTable = ObjectId.new("1.3.6.1.2.1.2.2")
      next_oid = ifTable
      while next_oid.subtree_of?(ifTable)
          response = manager.get_next(next_oid)
          varbind = response.varbind_list.first
          next_oid = varbind.name
          puts varbind.to_s
      end
  end

=== Get-Bulk Request

Get interface description and admin status for 10 rows of the ifTable.

  require 'snmp'
  include SNMP

  ifDescr_OID = ObjectId.new("1.3.6.1.2.1.2.2.1.2")
  ifAdminStatus_OID = ObjectId.new("1.3.6.1.2.1.2.2.1.7")
  MAX_ROWS = 10
  Manager.open(:Host => 'localhost') do |manager|
      response = manager.get_bulk(0, MAX_ROWS, [ifDescr_OID, ifAdminStatus_OID])
      list = response.varbind_list
      until list.empty?
          ifDescr = list.shift
          ifAdminStatus = list.shift
          puts "#{ifDescr.value}    #{ifAdminStatus.value}"
      end
  end

=== Trap Handling

Log traps to STDOUT.

  require 'snmp'
  require 'logger'

  log = Logger.new(STDOUT)
  m = SNMP::TrapListener.new do |manager|
      manager.on_trap_default do |trap|
          log.info trap.inspect
      end
  end
  m.join
   
== License

This SNMP Library is Copyright (c) 2004-2007 by David R. Halliday.  It is free
software.  Redistribution is permitted under the same terms and conditions as
the standard Ruby distribution.  See the COPYING file in the Ruby distribution
for details.