]> git.sesse.net Git - nms/blob - zyxel/konfgen.py
Add logging to mbd.
[nms] / zyxel / konfgen.py
1 #!/usr/bin/env python
2 # -*- coding: iso8859-1 -*-
3 #
4 # Dette er litt slitsomt, men virker.
5 # Scriptet produserer et runscript -script, som kjøres
6 # i minicom. 
7 #
8 # Du setter scriptet som _tolker_ i minicom. C-a O, valg "D".
9 # det skal stå som: "konfgen.py | runscript /dev/stdin"
10 #
11 # Husk at du må ha en fungerende minicom -konfig fra før. Rett
12 # serieport, 9600 8N1 osv. Med bare "minicom -o" skal du kunne
13 # trykke enter og få "please enter password"
14 #
15 # Start med "minicom -o -S hihi" (scriptfilen trenger ikke finnes)
16 #
17 # gangen i scriptet:
18 # * generisk hostoppsett (host, syslog, dato og saann)
19 # * ip-oppsett med router og slikt
20 # * vlan-oppsett
21
22 # start og sluttporter for å ikke stenge seg selv ute 
23 # mens man tester.
24 p1 = 1
25 p2 = 24+1
26
27 #MODE="RAW"
28 MODE="minicom"
29
30
31 import sys
32 import os
33 import time
34 from zyxelcommon import *
35
36 sys.stderr = open("/tmp/err","w+")
37 #sys.stdout = open("/tmp/out","w+")
38 sys.stdout = open(sys.argv[1],"w+")
39
40 def deduceSwitch():
41     # virker kun hvis man kjører manuelt.
42     if len(sys.argv) > 1:
43         (row, no) = sys.argv[1].split("-")
44         return (int(row), int(no))
45     else:
46         # okay, dette er for jævlig.
47         # jeg burde vinne en eller annen perlpris for dette.
48         # min ppid er også runscripts ppid. den har -S -argumentet oppgitt
49         # på kommandolinjen. (hihi i eksempel over)
50         # jeg vil hente den ut, slik at vi kan vatte inn svitsjnummer der.
51         log( "print inget argument. forsøker å dedusere fra prosesstabell")
52         lines = os.popen("ps -f --ppid %s -o pid,cmd 2>/dev/null" % os.getppid()).readlines()
53         for line in lines:
54             line = line.split()
55             if (line[1] == "runscript"):
56                 log( "linje som traff: %s" % line)
57                 tmp = line[3] # det som skrives etter -S
58                 row = tmp.split("-")[0]
59                 num = tmp.split("-")[1]
60                 log( "jeg tror vi snakker om %s" % line[3])
61                 return (int(row),int(num))
62         log("KLARTE IKKE DEDUSERE SVITSJ. AVBRYTER.")
63         if MODE == "minicom":
64             send("! killall -9 minicom")
65         sys.exit(255)
66
67 def log(text):
68     if MODE=="RAW":
69         # vi trenger ikke kommentarer i raw-mode.
70         return 
71     elif MODE == "minicom":
72         # runscript -format
73         sys.stdout.write("print \"%s\"\n" % text)
74     else:
75         sys.stderr.write(text +"\n")
76
77 def send(text):
78     if MODE=="RAW":
79         sys.stdout.write(text + "\n")
80     elif MODE == "minicom":
81         sys.stdout.write("send \"%s\"\n" % text)
82 #        sys.stdout.write("print \"kommendoen er: %s\"\n" % text)
83     else: 
84         sys.stdout.write(text + "\n")
85
86 sw = deduceSwitch()
87
88 if ((sw[0] % 2) == 0):
89     print "det er ingen svitsjer på rad %i" % sw[0]
90     sys.exit(255)
91
92 if (sw[1] > 6):
93     print "det er maks 6 svitsjer pr. bordrad!"
94     sys.exit(255)
95
96
97
98 GW              = "%s.%s.1" % (NETWORK, retSubnet(sw)) 
99 IP              = retIP(sw)
100 NAME            = "e%i-%isw" % sw
101 VLAN            = "%i%i" % sw
102 MNGTVLAN        = "90%s" % retSubnet(sw)[-1]
103
104 if MODE == "minicom":
105     log ("logger paa")
106     # logger paa
107     send( "exit")
108     send( "exit")
109     send( "z1234")
110
111
112 ### GENERISK HOSTOPPSETT
113 log( "* generisk")
114 send("sys hostname %s" % NAME)
115
116 send("sys syslog server %s" % LOGHOST)
117
118 send("sys snmp getCommunity 2 immer" )
119 send("sys snmp setCommunity 2 dabei") 
120 send("sys snmp trapCommunity 2 jungel")
121 send("sys snmp trapDest 2 %s"    % TRAPHOST)
122 send("sys snmp trustedHost 2 %s" % TRAPHOST)
123
124 send( "ip igmpsnoop enable")
125 # sansynligvis noe med broadcast storm control her
126
127 ### IP
128 log( "* ip")
129
130 send("ip ifconfig swif0 %s/24" % IP)
131 # konfig fra fabrikken. fjerner om den finnes.
132 send("ip route drop 192.168.1.0/24")
133 # naermeste distro
134 send("ip route add default %s" % GW)
135
136 ### bw-begrensninger
137 send("sys sw bw port set 1 * 25 0 200000 TIL-VERDEN")
138 send("sys sw bw port set 1 25 * 0 200000 FRA-VERDEN")
139
140 ### VLAN
141 log( "* vlan")
142 send("sys sw vlan type 802.1q")
143 # oppretter management-vlanet
144 send("sys sw vlan1q svlan setentry MNGT %s 25 fixed tag" % MNGTVLAN)
145 send("sys sw vlan1q svlan active %s" % MNGTVLAN )
146
147
148 # sletter defaulten
149 send("sys sw vlan1q svlan delentry 1")
150
151 # oppretter brukervlan
152 send("sys sw vlan1q svlan setentry %s %s 25 fixed tag" % (NAME, VLAN))
153 send("sys sw vlan1q svlan active %s" % VLAN)
154
155 # Usage: sw vlan1q svlan setentry <name> <VID> <PORT> <ADCTL> <TAGCTL>
156 # name maa stemme, ellers setter du nytt navn paa vlanet.
157 # adctl er forbidden,fixed,normal
158 # tagctl er tag / untag
159
160 for i in range(p1,p2): 
161     send("sys sw vlan1q svlan setentry %s   %s %i fixed untag"   % (NAME, VLAN, i))
162
163 for i in range(p1,p2): 
164     send("sys sw vlan1q svlan setentry MNGT %s %i forbidden tag" % (MNGTVLAN, i))
165
166
167 ### PORT-oppsett
168 log( "* portoppsett")
169 send("sys sw vlan1q port vlanTrunking 25 enable")
170
171 for i in range(p1,p2): 
172     send("sys sw vlan1q port accept %s untagged" % i)
173
174 for i in range(p1,p2): 
175     send("sys sw vlan1q port defaultVID %s %s" % (i, VLAN))
176
177 for i in range(p1,p2): 
178     send("sys sw bmstorm set %i 8192 egress" % i)
179     send("sys sw bmstorm set %i 8192 ingress" % i)
180
181 send("sys sw bmstorm set 25 32767 ingress")
182
183 # disse tar av uante grunner flere sekunder pr. kommando.
184 # det virker som at alle er disablet i utgangspunktet, så vi slå
185 # kun på den som trengs.
186 send("sys sw vlan1q port defaultVID 25 %s" % MNGTVLAN)
187
188 send("config save")
189 # sette mngt-vlan
190 send("sys sw vlan1q svlan cpu %s" % MNGTVLAN)
191
192 if MODE == "minicom":
193     log("logger av")
194     send("exit")
195     print "! killall -9 minicom"