Sha256: 061d7919997618db823de9b0c5adb5feba2bf5fb4d53a459e41320b0281093b1

Contents?: true

Size: 1.2 KB

Versions: 7

Compression:

Stored size: 1.2 KB

Contents

require 'rubygems'
require 'snmp'
require 'logger'

log = Logger.new($stdout)

mib = SNMP::MIB.new
mib.load_module("IF-MIB")
linkDown_OID = mib.oid("linkDown")

# 1 is "up" and 2 is "down" in the MIB
ADMIN_UP = 1
ADMIN_DOWN = 2

listener = SNMP::TrapListener.new(:Port => 1062, :Community => 'public') do |listener|
  log.info "Listening for linkDown traps"
  listener.on_trap(linkDown_OID) do |trap|
    vb_list = trap.vb_list
    up_time = vb_list[0].value    # standard varbind - always in v2c trap
    trap_oid = vb_list[1].value   # standard varbind - always in v2c trap

    # extract trap info - order determined by IF-MIB
    ifIndex = vb_list[2].value
    adminStatus = vb_list[3].value
    operStatus = vb_list[4].value

    # log stuff based on interface status
    if adminStatus == ADMIN_DOWN
      log.info "Interface #{ifIndex} turned down"
    else
      log.error "Problem on interface #{ifIndex}!  Link unintentionally down"
    end
  end

  listener.on_trap_v1 do |trap|
    log.warn "Unexpected v1 trap: #{trap.generic_trap}"
  end

  listener.on_trap_v2c do |trap|
    log.warn "Unexpected v2c trap: #{trap.trap_oid}"
  end
end

trap("INT") do
  puts "\nShutting down"
  listener.kill
end

listener.join

Version data entries

7 entries across 7 versions & 1 rubygems

Version Path
snmp-1.3.2 examples/link_down.rb
snmp-1.3.1 examples/link_down.rb
snmp-1.3.0 examples/link_down.rb
snmp-1.2.0 examples/link_down.rb
snmp-1.1.1 examples/link_down.rb
snmp-1.1.0 examples/link_down.rb
snmp-1.0.4 examples/link_down.rb