diff options
| author | ytti <saku@ytti.fi> | 2016-10-31 19:34:43 +0200 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2016-10-31 19:34:43 +0200 | 
| commit | 324113866a2e3092d72fb6c34c8530b1870f0a4c (patch) | |
| tree | 1f917ec23e2089032aba89371f0fc7b713e87fdf /lib | |
| parent | a87fc34a84a893b86d5ccb401d3bd4b9e544bfc2 (diff) | |
| parent | 2191cb239f14024327f29040e3548bf3b346f6cb (diff) | |
Merge pull request #601 from flokli/planet
add Planet SGS
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/oxidized/model/planetsgs.rb | 63 | 
1 files changed, 63 insertions, 0 deletions
| diff --git a/lib/oxidized/model/planetsgs.rb b/lib/oxidized/model/planetsgs.rb new file mode 100644 index 0000000..c240237 --- /dev/null +++ b/lib/oxidized/model/planetsgs.rb @@ -0,0 +1,63 @@ +class PlanetSGS < Oxidized::Model + +  prompt /^\r?([\w.@()-]+[#>]\s?)$/ +  comment  '! ' + +  # example how to handle pager +  #expect /^\s--More--\s+.*$/ do |data, re| +  # send ' ' +  # data.sub re, '' +  #end + +  # non-preferred way to handle additional PW prompt +  #expect /^[\w.]+>$/ do |data| +  #  send "enable\n" +  #  send vars(:enable) + "\n" +  #  data +  #end + +  cmd :all do |cfg| +    #cfg.gsub! /\cH+\s{8}/, ''         # example how to handle pager +    #cfg.gsub! /\cH+/, ''              # example how to handle pager +    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+).*/, '<secret hidden>' +    cfg.gsub! /^username \S+ password \d \S+/, '<secret hidden>' +    cfg.gsub! /^enable password \d \S+/, '<secret hidden>' +    cfg.gsub! /wpa-psk ascii \d \S+/, '<secret hidden>' +    cfg.gsub! /^tacacs-server key \d \S+/, '<secret hidden>' +    cfg +  end + +  cmd 'show version' do |cfg| +    comment cfg.each_line.to_a[0..-2].join +  end + + +  cmd 'show running-config' +   +  cmd 'show transceiver detail | include transceiver detail information|found|Type|length|Nominal|wavelength|Base information' do |cfg| +    comment cfg +  end + +  cfg :telnet do +    username /^Username:/ +    password /^Password:/ +  end + +  cfg :telnet, :ssh do +    post_login 'terminal length 0' +    # preferred way to handle additional passwords +    if vars :enable +      post_login do +        send "enable\n" +        cmd vars(:enable) +      end +    end +    pre_logout 'exit' +  end + +end | 
