blob: e85c90491e9a9ab2a464c67cd3ae7adf3621bc7e (
plain)
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
|
class Casa < Oxidized::Model
# Casa Systems CMTS
prompt /^([\w.@()-]+[#>]\s?)$/
comment '! '
cmd :secret do |cfg|
cfg.gsub! /^(snmp community) \S+/, '\\1 <configuration removed>'
cfg.gsub! /^(snmp comm-tbl) \S+ \S+/, '\\1 <removed> <removed>'
cfg.gsub! /^(console-password encrypted) \S+/, '\\1 <secret hidden>'
cfg.gsub! /^(password encrypted) \S+/, '\\1 <secret hidden>'
cfg.gsub! /^(tacacs-server key) \S+/, '\\1 <secret hidden>'
cfg
end
cmd :all do |cfg|
cfg.each_line.to_a[1..-2].join
end
cmd 'show system' do |cfg|
comment cfg.each_line.reject { |line| line.match /^\s+System (Time|Uptime): / }.join
end
cmd 'show version' do |cfg|
comment cfg
end
cmd 'show run'
cfg :telnet do
username /^Username:/
password /^Password:/
end
cfg :telnet, :ssh do
post_login 'page-off'
# preferred way to handle additional passwords
if vars :enable
post_login do
send "enable\n"
cmd vars(:enable)
end
end
pre_logout 'logout'
end
end
|