summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDanilo Sousa <danilopopeye@users.noreply.github.com>2017-09-12 11:04:59 -0300
committerGitHub <noreply@github.com>2017-09-12 11:04:59 -0300
commit1ec63b1bf1d3f6034665af7afe0a0a9df3928ec5 (patch)
tree98ada3521f86a6c24fa63d0d3d6aae4efcb7bac3
parent0293d1f584005789bce95bf0bfce7ba97cf6e80b (diff)
parent38faaed59a9c13f40177420cdda7958e53a69e36 (diff)
Merge pull request #993 from sfini/patch-3
Create acsw.rb for Cisco Ace
-rw-r--r--README.md1
-rw-r--r--lib/oxidized/model/acsw.rb67
2 files changed, 68 insertions, 0 deletions
diff --git a/README.md b/README.md
index f9c6955..ea75d07 100644
--- a/README.md
+++ b/README.md
@@ -91,6 +91,7 @@ Oxidized is a network device configuration backup tool. It's a RANCID replacemen
* Ciena
* [SAOS](lib/oxidized/model/saos.rb)
* Cisco
+ * [ACSW](lib/oxidized/model/acsw.rb)
* [AireOS](lib/oxidized/model/aireos.rb)
* [ASA](lib/oxidized/model/asa.rb)
* [AsyncOS](lib/oxidized/model/asyncos.rb)
diff --git a/lib/oxidized/model/acsw.rb b/lib/oxidized/model/acsw.rb
new file mode 100644
index 0000000..1aee2b6
--- /dev/null
+++ b/lib/oxidized/model/acsw.rb
@@ -0,0 +1,67 @@
+class ACSW < Oxidized::Model
+
+ prompt /([\w.@()\/\\-]+[#>]\s?)/
+ comment '! '
+
+ cmd :all do |cfg|
+ cfg.gsub! /^% Invalid input detected at '\^' marker\.$|^\s+\^$/, ''
+ cfg.each_line.to_a[1..-2].join
+ end
+
+ cmd :secret do |cfg|
+ cfg.gsub! /^(snmp-server community).*/, '\\1 <configuration removed>'
+ cfg.gsub! /^(username \S+ privilege \d+) (\S+).*/, '\\1 <secret hidden>'
+ cfg.gsub! /^(username \S+ password \d) (\S+)/, '\\1 <secret hidden>'
+ cfg.gsub! /^(username \S+ secret \d) (\S+)/, '\\1 <secret hidden>'
+ cfg.gsub! /^(enable (password|secret) \d) (\S+)/, '\\1 <secret hidden>'
+ cfg.gsub! /^(\s+(?:password|secret)) (?:\d )?\S+/, '\\1 <secret hidden>'
+ cfg.gsub! /^(.*wpa-psk ascii \d) (\S+)/, '\\1 <secret hidden>'
+ cfg.gsub! /^(.*key 7) (.*)/, '\\1 <secret hidden>'
+ cfg.gsub! /^(tacacs-server key \d) (\S+)/, '\\1 <secret hidden>'
+ cfg.gsub! /^(crypto isakmp key) (\S+) (.*)/, '\\1 <secret hidden> \\3'
+ cfg.gsub! /^(.*key 1 md5) (\d.+)/, '\\1 <secret hidden>'
+ cfg.gsub! /^(.*standby \d.+authentication).*/, '\\1 <secret hidden>'
+ cfg.gsub! /^(.*version 2c).*/, '\\1 <secret hidden>'
+ cfg
+ end
+
+
+ cmd 'show version' do |cfg|
+ comment cfg
+ end
+
+
+ cmd 'show inventory' do |cfg|
+ comment cfg
+ end
+
+
+ cmd 'show running-config' do |cfg|
+ cfg = cfg.each_line.to_a[3..-1]
+ cfg = cfg.reject { |line| line.match /^ntp clock-period / }.join
+ cfg.gsub! /^Current configuration : [^\n]*\n/, ''
+ cfg.gsub! /^\ tunnel\ mpls\ traffic-eng\ bandwidth[^\n]*\n*(
+ (?:\ [^\n]*\n*)*
+ tunnel\ mpls\ traffic-eng\ auto-bw)/mx, '\1'
+ cfg.gsub! /^([\s\t\!]*Last configuration change ).*/, ''
+ cfg.gsub! /^([\s\t\!]*NVRAM config last ).*/, ''
+ cfg
+ end
+
+ cfg :telnet do
+ username /.*login:/
+ password /^Password:/
+ end
+
+ cfg :telnet, :ssh do
+ if vars :enable
+ post_login do
+ send "enable\n"
+ cmd vars(:enable)
+ end
+ end
+ post_login 'terminal length 0'
+ pre_logout 'exit'
+ end
+
+end