diff options
| author | Robert Drake <rdrake@direcpath.com> | 2016-11-04 14:21:09 -0400 | 
|---|---|---|
| committer | Robert Drake <rdrake@direcpath.com> | 2016-11-04 14:21:09 -0400 | 
| commit | 8862e0b303b2fdc4c50992cfbffbbccb9b88bc91 (patch) | |
| tree | 753927172b750c5da382a17fb6acfe478973114d /lib | |
| parent | e5dc1dedf976a12c278f68c284c976ed462cdcb4 (diff) | |
This adds support for the Casa C1G CMTS
This will probably work for the other Casa CMTS as well.
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/oxidized/model/casa.rb | 46 | 
1 files changed, 46 insertions, 0 deletions
| diff --git a/lib/oxidized/model/casa.rb b/lib/oxidized/model/casa.rb new file mode 100644 index 0000000..e85c904 --- /dev/null +++ b/lib/oxidized/model/casa.rb @@ -0,0 +1,46 @@ +class Casa < Oxidized::Model +  # Casa Systems CMTS + +  prompt /^([\w.@()-]+[#>]\s?)$/ +  comment '! ' + +  cmd :secret do |cfg| +    cfg.gsub! /^(snmp community) \S+/, '\\1 <configuration removed>' +    cfg.gsub! /^(snmp comm-tbl) \S+ \S+/, '\\1 <removed> <removed>' +    cfg.gsub! /^(console-password encrypted) \S+/, '\\1 <secret hidden>' +    cfg.gsub! /^(password encrypted) \S+/, '\\1 <secret hidden>' +    cfg.gsub! /^(tacacs-server key) \S+/, '\\1 <secret hidden>' +    cfg +  end + +  cmd :all do |cfg| +    cfg.each_line.to_a[1..-2].join +  end + +  cmd 'show system' do |cfg| +    comment cfg.each_line.reject { |line| line.match /^\s+System (Time|Uptime): / }.join +  end + +  cmd 'show version' do |cfg| +    comment cfg +  end + +  cmd 'show run' + +  cfg :telnet do +    username /^Username:/ +    password /^Password:/ +  end + +  cfg :telnet, :ssh do +    post_login 'page-off' +    # preferred way to handle additional passwords +    if vars :enable +      post_login do +        send "enable\n" +        cmd vars(:enable) +      end +    end +    pre_logout 'logout' +  end +end | 
