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' |