forked from ytti/oxidized
-
Notifications
You must be signed in to change notification settings - Fork 0
/
gcombnps.rb
82 lines (68 loc) · 2.07 KB
/
gcombnps.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
class GcomBNPS < Oxidized::Model
# For switches from GCOM Technologies Co.,Ltd. running the "Broadband Network Platform Software"
# Author: Frederik Kriewitz <[email protected]>
#
# tested with:
# - S5330 (aka Fiberstore S3800)
prompt /^\r?([\w.@()-]+?(\(1-16 chars\))?[#>:]\s?)$/ # also match SSH password promt (post_login commands are sent after the first prompt)
comment '! '
# alternative to handle the SSH login, but this breaks telnet
# expect /^Password\(1-16 chars\):/ do |data|
# send @node.auth[:password] + "\n"
# ''
# end
# handle pager (can't be disabled?)
expect /^\.\.\.\.press ENTER to next line, CTRL_C to quit, other key to next page\.\.\.\.$/ do |data, re|
send ' '
data.sub re, ''
end
cmd :all do |cfg|
cfg = cfg.gsub " \e[73D\e[K", '' # remove garbage remaining from the pager
cfg.cut_both
end
cmd :secret do |cfg|
cfg.gsub! /^(snmp-server community)\s+[^\s]+\s+(.*)/, '\\1 <community hidden> \\2'
cfg
end
cmd 'show running-config' do |cfg|
cfg
end
cmd 'show interface sfp' do |cfg|
out = []
cfg.each_line do |line|
next if line.match /^ Temperature/
next if line.match /^ Voltage\(V\)/
next if line.match /^ Bias Current\(mA\)/
next if line.match /^ RX Power\(dBM\)/
next if line.match /^ TX Power\(dBM\)/
out << line
end
comment out.join
end
cmd 'show version' do |cfg|
comment cfg
end
cmd 'show system' do |cfg|
out = []
cfg.each_line do |line|
next if line.match /^system run time :/
next if line.match /^switch temperature :/
out << line
end
comment out.join
end
cfg :telnet do
username /^Username\(1-32 chars\):/
password /^Password\(1-16 chars\):/
end
cfg :ssh do
# the switch blindy accepts the SSH connection without password validation and then spawns a telnet login prompt
# first thing we've to send is the password
post_login do
send @node.auth[:password] + "\n"
end
end
cfg :telnet, :ssh do
pre_logout 'exit'
end
end