diff options
| author | ytti <saku@ytti.fi> | 2016-11-10 23:38:37 +0200 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2016-11-10 23:38:37 +0200 | 
| commit | 212214592b59c184cfed451e9529e9c7bb366b99 (patch) | |
| tree | 57916a1426b88d91511cbbc55c0d28e1a42d9d62 /lib/oxidized/model | |
| parent | c3514dc1402973162ecf5b4ce8cc88826191b0fb (diff) | |
| parent | eaaef17151017210bb20a936c89b43584914f92c (diff) | |
Merge pull request #614 from flokli/planet
add support for PLANET SG switches
Diffstat (limited to 'lib/oxidized/model')
| -rw-r--r-- | lib/oxidized/model/planet.rb (renamed from lib/oxidized/model/planetsgs.rb) | 30 | 
1 files changed, 25 insertions, 5 deletions
| diff --git a/lib/oxidized/model/planetsgs.rb b/lib/oxidized/model/planet.rb index c240237..05a369a 100644 --- a/lib/oxidized/model/planetsgs.rb +++ b/lib/oxidized/model/planet.rb @@ -1,4 +1,4 @@ -class PlanetSGS < Oxidized::Model +class Planet < Oxidized::Model    prompt /^\r?([\w.@()-]+[#>]\s?)$/    comment  '! ' @@ -33,15 +33,35 @@ class PlanetSGS < Oxidized::Model    end    cmd 'show version' do |cfg| -    comment cfg.each_line.to_a[0..-2].join +    cfg.gsub! "\n\r", "\n" +    @planetgs = true if cfg.match /^System Name\w*:\w*GS-.*$/ +    @planetsgs = true if cfg.match /SGS-(.*) Device, Compiled on .*$/ + +    cfg = cfg.each_line.to_a[0...-2] + +   # Strip system time and system uptime from planet gs switches +    cfg = cfg.reject { |line| line.match /System Time\s*:.*/ } +    cfg = cfg.reject { |line| line.match /System Uptime\s*:.*/ } + +    comment cfg.join    end -  cmd 'show running-config' +  cmd 'show running-config' do |cfg| +    cfg.gsub! "\n\r", "\n" +    cfg = cfg.each_line.to_a + +    cfg = cfg.reject { |line| line.match "Building configuration..." } -  cmd 'show transceiver detail | include transceiver detail information|found|Type|length|Nominal|wavelength|Base information' do |cfg| -    comment cfg +    if @planetsgs +      cfg << cmd('show transceiver detail | include transceiver detail information|found|Type|length|Nominal|wavelength|Base information') do |cfg| +        comment cfg +      end +    end + +    cfg.join    end +      cfg :telnet do      username /^Username:/ | 
