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 /lib/oxidized/model | |
| parent | e457762085c97879b9f2a199a5cb76dcfbe60912 (diff) | |
| parent | 558db95a7bb3271f468d3dd2b3f4d4e14c4b33df (diff) | |
Merge pull request #757 from crami/master
added model for OneAccess OneOS Voice Gateways/Routers
Diffstat (limited to 'lib/oxidized/model')
| -rw-r--r-- | lib/oxidized/model/oneos.rb | 58 | 
1 files changed, 58 insertions, 0 deletions
| 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 | 
