summaryrefslogtreecommitdiff
path: root/lib/oxidized/model/masteros.rb
diff options
context:
space:
mode:
authorytti <saku@ytti.fi>2015-08-26 16:56:19 +0300
committerytti <saku@ytti.fi>2015-08-26 16:56:19 +0300
commite52bffc775857d13e12fb94acf5c5532f4d52aae (patch)
tree2816758dfbe1aeeac8fe8dbe39585a99f79dc249 /lib/oxidized/model/masteros.rb
parenta0cd3304e16a428e10203c47d14b780f327503ab (diff)
parent42cd484653da2f64a716be6b96efbde6f59fea83 (diff)
Merge pull request #167 from kwibbly/master
Add support for MRV Master-OS
Diffstat (limited to 'lib/oxidized/model/masteros.rb')
-rw-r--r--lib/oxidized/model/masteros.rb46
1 files changed, 46 insertions, 0 deletions
diff --git a/lib/oxidized/model/masteros.rb b/lib/oxidized/model/masteros.rb
new file mode 100644
index 0000000..3f5a2fc
--- /dev/null
+++ b/lib/oxidized/model/masteros.rb
@@ -0,0 +1,46 @@
+class MasterOS < Oxidized::Model
+
+ # MRV MasterOS model #
+
+comment '!'
+
+ cmd :secret do |cfg|
+ cfg.gsub! /^(snmp-server community).*/, '\\1 <configuration removed>'
+ cfg.gsub! /username (\S+) password encrypted (\S+) class (\S+).*/, '<secret hidden>'
+ cfg
+ end
+
+ cmd :all do |cfg|
+ cfg.each_line.to_a[1..-2].join
+ end
+
+ cmd 'show inventory' do |cfg|
+ cfg = cfg.each_line.to_a[0..-2].join
+ comment cfg
+ end
+
+ cmd 'show plugins' do |cfg|
+ comment cfg
+ end
+
+ cmd 'show hw-config' do |cfg|
+ comment cfg
+ end
+
+ cmd 'show running-config' do |cfg|
+ cfg = cfg.each_line.to_a[3..-1].join
+ cfg
+ end
+
+ cfg :telnet, :ssh do
+ post_login 'no pager'
+ if vars :enable
+ post_login do
+ send "enable\n"
+ send vars(:enable) + "\n"
+ end
+ end
+ pre_logout 'exit'
+ end
+
+end \ No newline at end of file