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 |