diff options
| author | Robert Drake <rdrake@direcpath.com> | 2016-11-04 14:26:20 -0400 | 
|---|---|---|
| committer | Robert Drake <rdrake@direcpath.com> | 2016-11-04 14:26:20 -0400 | 
| commit | 2b05133b001c564676554bae05baa34a9900fbe0 (patch) | |
| tree | 66ef19481fc43b470d81e02e4176de8f440ec6b4 /lib/oxidized | |
| parent | e5dc1dedf976a12c278f68c284c976ed462cdcb4 (diff) | |
This adds support for Hatteras Networks devices
Diffstat (limited to 'lib/oxidized')
| -rw-r--r-- | lib/oxidized/model/hatteras.rb | 52 | 
1 files changed, 52 insertions, 0 deletions
| diff --git a/lib/oxidized/model/hatteras.rb b/lib/oxidized/model/hatteras.rb new file mode 100644 index 0000000..4192cbc --- /dev/null +++ b/lib/oxidized/model/hatteras.rb @@ -0,0 +1,52 @@ +class Hatteras < Oxidized::Model +  # Hatteras Networks + +  prompt /^(\r?[\w.@()-]+[#>]\s?)$/ +  comment '# ' + +  expect /WARNING: System configuration changes will be lost when the device restarts./ do |data, re| +    send "y\r" +    data.sub re, '' +  end + + +  cmd :secret do |cfg| +    cfg.gsub! /^(community) \S+/, '\\1 "<configuration removed>"' +    cfg.gsub! /^(communityString) "\S+"/, '\\1 "<configuration removed>"' +    cfg.gsub! /^(key) "\S+"/, '\\1 "<secret hidden>"' +    cfg +  end + +  cmd :all do |cfg| +    cfg.each_line.to_a[1..-2].join +  end + +  cmd "show switch\r" do |cfg| +    cfg = cfg.each_line.reject { |line| line.match /Switch uptime|Switch temperature|Last reset reason/ or +                                          line.match /TermCpuUtil|^\s+\^$|ERROR: Bad command/ }.join +    comment cfg +  end + +  cmd "show card\r" do |cfg| +    cfg = cfg.each_line.reject { |line| line.match /Card uptime|Card temperature|Last reset reason/ or +                                          line.match /TermCpuUtil|^\s+\^$|ERROR: Bad command/ }.join +    comment cfg +  end + +  cmd "show sfp *\r" do |cfg| +    comment cfg +  end + +  cmd "show config run\r" do |cfg| +    cfg +  end + +  cfg :telnet do +    username /^Login:/ +    password /^Password:/ +  end + +  cfg :telnet, :ssh do +    pre_logout "logout\r" +  end +end | 
