forked from ytti/oxidized
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcumulus.rb
124 lines (93 loc) · 3.19 KB
/
cumulus.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
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
class Cumulus < Oxidized::Model
using Refinements
prompt /^(([\w.-]*)@(.*)):/
comment '# '
# add a comment in the final conf
def add_comment(comment)
"\n###### #{comment} ######\n"
end
cmd :all do |cfg|
cfg.cut_both
end
cmd :secret do |cfg|
cfg.gsub! /password (\S+)/, 'password <hidden>'
cfg
end
# show the persistent configuration
pre do
use_nclu = vars(:cumulus_use_nclu) || false
use_nvue = vars(:cumulus_use_nvue) || false
if use_nclu
cfg = cmd 'net show configuration commands'
elsif use_nvue
cfg = cmd 'nv config show --color off'
else
# Set FRR or Quagga in config
routing_daemon = vars(:cumulus_routing_daemon) ? vars(:cumulus_routing_daemon).downcase : 'quagga'
routing_conf_file = routing_daemon == 'frr' ? 'frr.conf' : 'Quagga.conf'
routing_daemon_shout = routing_daemon.upcase
cfg = add_comment 'THE HOSTNAME'
cfg += cmd 'cat /etc/hostname'
cfg += add_comment 'THE HOSTS'
cfg += cmd 'cat /etc/hosts'
cfg += add_comment 'THE INTERFACES'
cfg += cmd 'grep -r "" /etc/network/interface* | cut -d "/" -f 4-'
cfg += add_comment 'RESOLV.CONF'
cfg += cmd 'cat /etc/resolv.conf'
cfg += add_comment 'NTP.CONF'
cfg += cmd 'cat /etc/ntp.conf'
cfg += add_comment 'SNMP settings'
cfg += cmd 'cat /etc/snmp/snmpd.conf'
cfg += add_comment "#{routing_daemon_shout} DAEMONS"
cfg += cmd "cat /etc/#{routing_daemon}/daemons"
cfg += add_comment "#{routing_daemon_shout} ZEBRA"
cfg += cmd "cat /etc/#{routing_daemon}/zebra.conf"
cfg += add_comment "#{routing_daemon_shout} BGP"
cfg += cmd "cat /etc/#{routing_daemon}/bgpd.conf"
cfg += add_comment "#{routing_daemon_shout} OSPF"
cfg += cmd "cat /etc/#{routing_daemon}/ospfd.conf"
cfg += add_comment "#{routing_daemon_shout} OSPF6"
cfg += cmd "cat /etc/#{routing_daemon}/ospf6d.conf"
cfg += add_comment "#{routing_daemon_shout} CONF"
cfg += cmd "cat /etc/#{routing_daemon}/#{routing_conf_file}"
cfg += add_comment 'MOTD'
cfg += cmd 'cat /etc/motd'
cfg += add_comment 'PASSWD'
cfg += cmd 'cat /etc/passwd'
cfg += add_comment 'SWITCHD'
cfg += cmd 'cat /etc/cumulus/switchd.conf'
cfg += add_comment 'PORTS'
cfg += cmd 'cat /etc/cumulus/ports.conf'
cfg += add_comment 'TRAFFIC'
cfg += cmd 'cat /etc/cumulus/datapath/traffic.conf'
cfg += add_comment 'ACL'
cfg += cmd 'cat /etc/cumulus/acl/policy.conf'
cfg += add_comment 'DHCP-RELAY'
cfg += cmd 'cat /etc/default/isc-dhcp-relay'
cfg += add_comment 'VERSION'
cfg += cmd 'cat /etc/cumulus/etc.replace/os-release'
cfg += add_comment 'License'
cfg += cmd 'cl-license'
end
cfg
end
cfg :telnet do
username /^Username:/
password /^Password:/
end
cfg :telnet, :ssh do
post_login do
if vars(:enable) == true
cmd "sudo su -", /^\[sudo\] password/
cmd @node.auth[:password]
elsif vars(:enable)
cmd "su -", /^Password:/
cmd vars(:enable)
end
end
pre_logout do
cmd "exit" if vars(:enable)
end
pre_logout 'exit'
end
end