diff options
| author | ytti <saku@ytti.fi> | 2017-03-07 21:56:16 +0200 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2017-03-07 21:56:16 +0200 | 
| commit | 45bc305a2b60a31638ad95d8c1b87e5dbf74a5c5 (patch) | |
| tree | 9aad1abb7718a477a52d31dade4f1a4d705a8923 | |
| parent | e457762085c97879b9f2a199a5cb76dcfbe60912 (diff) | |
| parent | 558db95a7bb3271f468d3dd2b3f4d4e14c4b33df (diff) | |
Merge pull request #757 from crami/master
added model for OneAccess OneOS Voice Gateways/Routers
| -rw-r--r-- | README.md | 2 | ||||
| -rw-r--r-- | lib/oxidized/model/oneos.rb | 58 | ||||
| -rw-r--r-- | oxidized.gemspec | 2 | 
3 files changed, 61 insertions, 1 deletions
| @@ -136,6 +136,8 @@ Oxidized is a network device configuration backup tool. It's a RANCID replacemen     * [WISP Switch (As Netonix)](lib/oxidized/model/netonix.rb)   * Nokia (formerly TiMetra, Alcatel, Alcatel-Lucent)     * [SR OS (TiMOS)](lib/oxidized/model/timos.rb) + * OneAccess +   * [OneOS](lib/oxidized/model/oneos.rb)   * Opengear     * [Opengear](lib/oxidized/model/opengear.rb)   * Palo Alto diff --git a/lib/oxidized/model/oneos.rb b/lib/oxidized/model/oneos.rb new file mode 100644 index 0000000..eeaa2ce --- /dev/null +++ b/lib/oxidized/model/oneos.rb @@ -0,0 +1,58 @@ +class OneOS < Oxidized::Model + +  prompt /^([\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 set-read-community ").*+?(".*)$/, '\\1<secret hidden>\\2' +    cfg +  end + +  cmd 'show version' do |cfg| +    comment cfg +  end + +  cmd 'show running-config' do |cfg| +    cfg = cfg.each_line.to_a[0..-1].join +    cfg.gsub! /^Building configuration...\s*[^\n]*\n/, '' +    cfg.gsub! /^Current configuration :\s*[^\n]*\n/, '' +    cfg +  end + +  cfg :telnet do +    username /^Username:/ +    password /^Password:/ +  end + +  cfg :telnet, :ssh do +    # preferred way to handle additional passwords +    if vars :enable +      post_login do +        send "enable\n" +        cmd vars(:enable) +      end +    end +    post_login 'term len 0' +    pre_logout 'exit' +  end + +end diff --git a/oxidized.gemspec b/oxidized.gemspec index c12dcb5..78324d4 100644 --- a/oxidized.gemspec +++ b/oxidized.gemspec @@ -25,7 +25,7 @@ Gem::Specification.new do |s|    s.add_runtime_dependency 'rugged',  '~> 0.21',  '>= 0.21.4'    if defined?(RUBY_VERSION) && RUBY_VERSION > '2.3' -      s.add_runtime_dependency 'net-telnet' +      s.add_runtime_dependency 'net-telnet', '~> 0'    end    s.add_development_dependency 'pry',      '~> 0' | 
