From 76b9a6ea902ce699f90305ec7a58882da798acbe Mon Sep 17 00:00:00 2001 From: ospfbgp Date: Mon, 15 May 2017 01:01:16 -0400 Subject: Add support for Avaya BOSS Add support for Avaya Baystack Operating System Software(BOSS) --- lib/oxidized/model/boss.rb | 80 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 80 insertions(+) create mode 100644 lib/oxidized/model/boss.rb (limited to 'lib/oxidized/model') diff --git a/lib/oxidized/model/boss.rb b/lib/oxidized/model/boss.rb new file mode 100644 index 0000000..93f9903 --- /dev/null +++ b/lib/oxidized/model/boss.rb @@ -0,0 +1,80 @@ +class Boss < Oxidized::Model + # Avaya Baystack Operating System Software(BOSS) + # Created by danielcoxman@gmail.com + # May 15, 2017 + # This was tested on ers3510, ers5530, ers4850, ers5952 + # ssh and telnet were tested with banner and without + + comment '! ' + + prompt /^[^\s#>]+[#>]$/ + + # Handle the banner + # to disable the banner on BOSS the configuration parameter is "banner disabled" + expect /Enter Ctrl-Y to begin\./ do |data, re| + send "\cY" + data.sub re, '' + end + + # Handle the Failed retries since last login + # no known way to disable other than to implement radius authentication + expect /Press ENTER to continue/ do |data, re| + send "\n" + data.sub re, '' + end + + # Handle the menu on the older BOSS example ers55xx, ers56xx + # to disable them menu on BOSS the configuration parameter is "cmd-interface cli" + expect /ommand Line Interface\.\.\./ do |data, re| + send "c" + data.sub re, '' + end + + # needed for proper formatting + cmd('') { |cfg| comment "#{cfg}\n" } + + # Do a sys-info and check and see if it supports stack + cmd 'show sys-info' do |cfg| + @stack = true if cfg.match /Stack/ + cfg.gsub! /(^((.*)sysUpTime(.*))$)/, 'removed sysUpTime' + cfg.gsub! /(^((.*)sysNtpTime(.*))$)/, 'removed sysNtpTime' + cfg.gsub! /(^((.*)sysRtcTime(.*))$)/, 'removed sysNtpTime' + cfg.gsub! /\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2} .*/, '' + comment "#{cfg}\n" + end + + # if a stack then collect the stacking information + cmd 'show stack-info' do |cfg| + if @stack + cfg.gsub! /\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2} .*/, '' + comment "#{cfg}\n" + end + end + + cmd 'show running-config' do |cfg| + cfg.gsub! /^show running-config/, '! show running-config' + # remove cli timestamp + cfg.gsub! /\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2} .*/, '' + cfg.gsub! /^[^\s#>]+[#>]$/, '' + cfg.gsub! /^! clock set.*/, '! removed clock set' + cfg + end + + cfg :telnet do + username /Username: / + password /Password: / + end + + cfg :telnet, :ssh do + pre_logout do + # Backup the running-config via tftp to a tftpserver of your choice + #send "copy running-config tftp address x.x.x.x filename " + node.name + ".cli\n" + send "logout\n" + end + post_login do + send "terminal length 0\n" + send "terminal width 132\n" + end + end + +end -- cgit v1.2.1 From dd8101df0aa579405eab958da623fb36ef3231ab Mon Sep 17 00:00:00 2001 From: ospfbgp Date: Mon, 15 May 2017 02:12:18 -0400 Subject: Update boss.rb had some test code that needed to be removed --- lib/oxidized/model/boss.rb | 16 ++++++---------- 1 file changed, 6 insertions(+), 10 deletions(-) (limited to 'lib/oxidized/model') diff --git a/lib/oxidized/model/boss.rb b/lib/oxidized/model/boss.rb index 93f9903..02201a1 100644 --- a/lib/oxidized/model/boss.rb +++ b/lib/oxidized/model/boss.rb @@ -39,6 +39,7 @@ class Boss < Oxidized::Model cfg.gsub! /(^((.*)sysUpTime(.*))$)/, 'removed sysUpTime' cfg.gsub! /(^((.*)sysNtpTime(.*))$)/, 'removed sysNtpTime' cfg.gsub! /(^((.*)sysRtcTime(.*))$)/, 'removed sysNtpTime' + # remove timestamp cfg.gsub! /\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2} .*/, '' comment "#{cfg}\n" end @@ -46,6 +47,7 @@ class Boss < Oxidized::Model # if a stack then collect the stacking information cmd 'show stack-info' do |cfg| if @stack + # remove timestamp cfg.gsub! /\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2} .*/, '' comment "#{cfg}\n" end @@ -53,7 +55,7 @@ class Boss < Oxidized::Model cmd 'show running-config' do |cfg| cfg.gsub! /^show running-config/, '! show running-config' - # remove cli timestamp + # remove timestamp cfg.gsub! /\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2} .*/, '' cfg.gsub! /^[^\s#>]+[#>]$/, '' cfg.gsub! /^! clock set.*/, '! removed clock set' @@ -66,15 +68,9 @@ class Boss < Oxidized::Model end cfg :telnet, :ssh do - pre_logout do - # Backup the running-config via tftp to a tftpserver of your choice - #send "copy running-config tftp address x.x.x.x filename " + node.name + ".cli\n" - send "logout\n" - end - post_login do - send "terminal length 0\n" - send "terminal width 132\n" - end + pre_logout 'logout' + post_login 'terminal length 0' + post_login 'terminal width 132' end end -- cgit v1.2.1