diff options
author | ytti <saku@ytti.fi> | 2015-10-12 01:53:22 +0300 |
---|---|---|
committer | ytti <saku@ytti.fi> | 2015-10-12 01:53:22 +0300 |
commit | b5e8078318c1c3e50198acdaa698a113012bfa41 (patch) | |
tree | 402d24e1cb7219b1b15d7af9e8aa30fcb767bee1 /lib | |
parent | 8a5cf58297caabb2335dde98adf9f7307432b92e (diff) | |
parent | 9819805419d48662a17cf5553fef29aecb5c424f (diff) |
Merge pull request #215 from nickhilliard/nf-model-add-arris-c4
Add support for Arris C4 CMTS
Diffstat (limited to 'lib')
-rw-r--r-- | lib/oxidized/model/c4cmts.rb | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/lib/oxidized/model/c4cmts.rb b/lib/oxidized/model/c4cmts.rb new file mode 100644 index 0000000..150029c --- /dev/null +++ b/lib/oxidized/model/c4cmts.rb @@ -0,0 +1,52 @@ +class C4CMTS < Oxidized::Model + + # Arris C4 CMTS + + prompt /^([\w.@:\/-]+[#>]\s?)$/ + comment '! ' + + cmd :all do |cfg| + cfg.each_line.to_a[1..-2].map{|line|line.delete("\r").rstrip}.join("\n") + "\n" + end + + cmd :secret do |cfg| + cfg.gsub! /(.+)\s+encrypted-password\s+\w+\s+(.*)/, '\\1 <secret hidden> \\2' + cfg.gsub! /(snmp-server community)\s+".*"\s+(.*)/, '\\1 <secret hidden> \\2' + cfg.gsub! /(tacacs.*\s+key)\s+".*"\s+(.*)/, '\\1 <secret hidden> \\2' + cfg.gsub! /(cable authstring)\s+\w+\s+(.*)/, '\\1 <secret hidden> \\2' + cfg + end + + cmd 'show environment' do |cfg| + cfg.gsub! /\s+[\-\d]+\s+C\s+[\(\s\d]+\s+\F\)/, '' # remove temperature readings + cfg.each_line.to_a[1..-2].join + comment cfg + end + + cmd 'show version' do |cfg| + # remove uptime readings at char 55 and beyond + cfg = cfg.each_line.map{|line|line.rstrip.slice(0..54)}.join("\n") + "\n" + comment cfg + end + + cmd 'show running-config' do |cfg| + cfg = cfg.each_line.to_a[1..-2].join + cfg + end + + cfg :telnet do + username /^Username:/ + password /^Password:/ + end + + cfg :telnet, :ssh do + if vars :enable + post_login do + send "enable\n" + send vars(:enable) + "\n" + end + end + pre_logout 'exit' + end + +end |