From 2de3af62493cc7743d4f6d7981f3952ca040a9fe Mon Sep 17 00:00:00 2001 From: Anton Aksola Date: Mon, 7 Apr 2014 10:24:16 +0300 Subject: add ACOS model for A10 AX and Thunder series --- lib/oxidized/model/acos.rb | 69 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 69 insertions(+) create mode 100644 lib/oxidized/model/acos.rb diff --git a/lib/oxidized/model/acos.rb b/lib/oxidized/model/acos.rb new file mode 100644 index 0000000..8ac9165 --- /dev/null +++ b/lib/oxidized/model/acos.rb @@ -0,0 +1,69 @@ +class ACOS < Oxidized::Model + # A10 ACOS model for AX and Thunder series + + comment '! ' + + ##ACOS prompt changes depending on the state of the device + prompt /^([-\w.\/:?\[\]\(\)]+[#>]\s?)$/ + + cmd 'show version' do |cfg| + comment cfg + end + + cmd 'show license' do |cfg| + comment cfg + end + + cmd 'show running-config all-partitions' + + cmd 'show aflex all-partitions' do |cfg| + @partitions_aflex = cfg.lines.each_with_object({}) do |l,h| + h[$1] = [] if l.match /partition: (.+)/ + # only consider scripts that have passed syntax check + h[h.keys.last] << $1 if l.match /^([\w-]+) +Check/ + end + '' + end + + cmd :all do |cfg, cmdstring| + new_cfg = comment "COMMAND: #{cmdstring}\n" + new_cfg << cfg.each_line.to_a[1..-2].join + end + + pre do + unless @partitions_aflex.empty? + out = [] + @partitions_aflex.each do |partition,arules| + out << "! partition: #{partition}" + arules.each do |name| + cmd("show aflex #{name} partition #{partition}") do |cfg| + content = cfg.split(/Content:/).last.strip + out << "aflex create #{name}" + out << content + out << ".\n" + end + end + end + out.join "\n" + end + end + + cfg :telnet do + username /login:/ + password /^Password:/ + end + + cfg :telnet, :ssh do + # preferred way to handle additional passwords + if CFG.vars[:enable] and CFG.vars[:enable] != '' + post_login do + send "enable\n" + send CFG.vars[:enable] + "\n" + end + end + post_login 'terminal length 0' + post_login 'terminal width 0' + pre_logout "exit\nexit\ny" + end + +end -- cgit v1.2.1