summaryrefslogtreecommitdiff
path: root/lib/oxidized/model/netgear.rb
diff options
context:
space:
mode:
authorytti <saku@ytti.fi>2017-04-27 08:45:37 -0700
committerGitHub <noreply@github.com>2017-04-27 08:45:37 -0700
commit23d55da7338c96158f009252f1bd522da88a36b2 (patch)
tree4d9385d3407a978eaf948cc22d04ddeaba98966f /lib/oxidized/model/netgear.rb
parentccb28d79b5cdc1d57f75ab156ad360161974b927 (diff)
parent17b458de0333076c07a215c65d7596b9f3eda7d1 (diff)
Merge pull request #702 from aschaber1/feature/netgear
add support for netgear switch
Diffstat (limited to 'lib/oxidized/model/netgear.rb')
-rw-r--r--lib/oxidized/model/netgear.rb32
1 files changed, 32 insertions, 0 deletions
diff --git a/lib/oxidized/model/netgear.rb b/lib/oxidized/model/netgear.rb
new file mode 100644
index 0000000..08c64d3
--- /dev/null
+++ b/lib/oxidized/model/netgear.rb
@@ -0,0 +1,32 @@
+class Netgear < Oxidized::Model
+
+ comment '!'
+ prompt /^(\([\w-]+\)\s[#>])$/
+
+ cmd :secret do |cfg|
+ cfg.gsub!(/password (\S+)/, 'password <hidden>')
+ cfg
+ end
+
+ cfg :telnet, :ssh do
+ if vars :enable
+ post_login do
+ cmd 'enable'
+ # Interpret enable: true as meaning we won't be prompted for a password
+ unless vars(:enable).is_a? TrueClass
+ expect /[pP]assword:\s?$/
+ cmd vars(:enable) + "\n"
+ end
+ expect /^.+[#]$/
+ end
+ end
+ post_login 'terminal length 0'
+ pre_logout 'exit'
+ pre_logout 'quit'
+ end
+
+ cmd 'show running-config' do |cfg|
+ cfg.gsub! /^(!.*Time).*$/, '\1'
+ end
+
+end