From 8a63ff7e333457de9f6145e83c0ed3f1ebdba136 Mon Sep 17 00:00:00 2001 From: Reinier Schoof Date: Fri, 25 Sep 2015 14:34:33 +0200 Subject: added model for older Foundry/Brocade model switches Oxidized model for Foundry/Brocade switch models that run IronWare but require carriage return instead of newline on enable command and require different filters for temperature/uptime lines --- lib/oxidized/model/foundry.rb | 58 +++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 58 insertions(+) create mode 100644 lib/oxidized/model/foundry.rb diff --git a/lib/oxidized/model/foundry.rb b/lib/oxidized/model/foundry.rb new file mode 100644 index 0000000..beaf49d --- /dev/null +++ b/lib/oxidized/model/foundry.rb @@ -0,0 +1,58 @@ +# Oxidized model for Foundry/Brocade switch models that run IronWare +# but require carriage return instead of newline on enable command +# and require different filters for temperature/uptime lines +class Foundry < Oxidized::Model + + prompt /^.*(telnet|ssh)\@.+[>#]\s?$/i + comment '! ' + + cmd :all do |cfg| + cfg.each_line.to_a[1..-2].join + end + + cmd 'show running-config' do |cfg| + arr = cfg.each_line.to_a + arr[3..-1].join unless arr.length <= 3 + end + + cmd 'show version' do |cfg| + cfg.gsub! /(^((.*)[Ss]ystem uptime(.*))$)/, '' #remove unwanted line system uptime + + comment cfg + end + + cmd 'show chassis' do |cfg| + cfg.encode!("UTF-8", :invalid => :replace) #sometimes ironware returns broken encoding + cfg.gsub! /\d{2}\.\d deg-C$/, 'XX.X deg-C' + + comment cfg + end + + cmd 'show flash' do |cfg| + comment cfg + end + + cmd 'show module' do |cfg| + comment cfg + end + + cfg :telnet do + username /^Please Enter Login Name:/ + password /^Please Enter Password:/ + end + + #handle pager with enable + cfg :telnet, :ssh do + if vars :enable + post_login do + send "enable\r" + send vars(:enable) + "\r" + end + end + post_login 'skip-page-display' + pre_logout 'logout' + pre_logout 'exit' + pre_logout 'exit' + end + +end -- cgit v1.2.1 From bf999706f0be794563b78fb90999b5c5fa8e54d5 Mon Sep 17 00:00:00 2001 From: Reinier Schoof Date: Mon, 28 Sep 2015 09:37:47 +0200 Subject: merged models for older and newer MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit - login prompt matches both older and newer version of IronWare - send carriage returns for both versions as it should make no difference - made temperature filters compatible and removed obsolete ā€™dā€™ character --- lib/oxidized/model/foundry.rb | 58 ------------------------------------------ lib/oxidized/model/ironware.rb | 18 +++++++------ 2 files changed, 10 insertions(+), 66 deletions(-) delete mode 100644 lib/oxidized/model/foundry.rb diff --git a/lib/oxidized/model/foundry.rb b/lib/oxidized/model/foundry.rb deleted file mode 100644 index beaf49d..0000000 --- a/lib/oxidized/model/foundry.rb +++ /dev/null @@ -1,58 +0,0 @@ -# Oxidized model for Foundry/Brocade switch models that run IronWare -# but require carriage return instead of newline on enable command -# and require different filters for temperature/uptime lines -class Foundry < Oxidized::Model - - prompt /^.*(telnet|ssh)\@.+[>#]\s?$/i - comment '! ' - - cmd :all do |cfg| - cfg.each_line.to_a[1..-2].join - end - - cmd 'show running-config' do |cfg| - arr = cfg.each_line.to_a - arr[3..-1].join unless arr.length <= 3 - end - - cmd 'show version' do |cfg| - cfg.gsub! /(^((.*)[Ss]ystem uptime(.*))$)/, '' #remove unwanted line system uptime - - comment cfg - end - - cmd 'show chassis' do |cfg| - cfg.encode!("UTF-8", :invalid => :replace) #sometimes ironware returns broken encoding - cfg.gsub! /\d{2}\.\d deg-C$/, 'XX.X deg-C' - - comment cfg - end - - cmd 'show flash' do |cfg| - comment cfg - end - - cmd 'show module' do |cfg| - comment cfg - end - - cfg :telnet do - username /^Please Enter Login Name:/ - password /^Please Enter Password:/ - end - - #handle pager with enable - cfg :telnet, :ssh do - if vars :enable - post_login do - send "enable\r" - send vars(:enable) + "\r" - end - end - post_login 'skip-page-display' - pre_logout 'logout' - pre_logout 'exit' - pre_logout 'exit' - end - -end diff --git a/lib/oxidized/model/ironware.rb b/lib/oxidized/model/ironware.rb index 805e07b..870d45a 100644 --- a/lib/oxidized/model/ironware.rb +++ b/lib/oxidized/model/ironware.rb @@ -20,8 +20,8 @@ class IronWare < Oxidized::Model end cmd 'show running-config' do |cfg| - cfg = cfg.each_line.to_a[3..-1].join - cfg + arr = cfg.each_line.to_a + arr[3..-1].join unless arr.length < 3 end cmd 'show version' do |cfg| @@ -36,7 +36,7 @@ class IronWare < Oxidized::Model cfg.gsub! /(^((.*)Current temp(.*))$)/, '' #remove unwanted lines current temperature cfg.gsub! /Speed = [A-Z]{3} \(\d{2}\%\)/, '' #remove unwanted lines Speed Fans cfg.gsub! /current speed is [A-Z]{3} \(\d{2}\%\)/, '' - cfg.gsub! /Fan controlled temperature: \d{2}\.\d deg-C/, 'Fan controlled temperature: XX.X d deg-C' + cfg.gsub! /\d{2}\.\d deg-C/, 'XX.X deg-C' if cfg.include? "TEMPERATURE" sc = StringScanner.new cfg out = '' @@ -59,16 +59,18 @@ class IronWare < Oxidized::Model end cfg :telnet do - username /^Username:/ - password /^Password:/ + # match expected prompts on both older and newer + # versions of IronWare + username /^(Please Enter Login Name|Username):/ + password /^(Please Enter )Password:/ end #handle pager with enable cfg :telnet, :ssh do if vars :enable post_login do - send "enable\n" - send vars(:enable) + "\n" + send "enable\r\n" + send vars(:enable) + "\r\n" end end post_login '' @@ -79,4 +81,4 @@ class IronWare < Oxidized::Model pre_logout 'exit' end -end \ No newline at end of file +end -- cgit v1.2.1