source: genesis/config/iris/node/FreeBSD/8.0-RELEASE/wleiden.pl@ 9254

Last change on this file since 9254 was 9254, checked in by rick, 14 years ago

Proper validation of iface DHCP.

  • Property svn:executable set to *
File size: 10.4 KB
Line 
1#!/usr/bin/perl -w
2#
3# Copyright 2005 Stichting Wireless Leiden
4# maart 2004 rick@wirelessleiden.nl
5#
6
7# Config located at other file
8my $conf_file="./genesis.conf";
9do($conf_file) || die("Cann't open $conf_file");
10################ END OF CONFIG ##########################
11
12#variablen
13my $time=gmtime();
14my $source=`/bin/hostname`;
15chomp($source);
16
17
18#slurp IP berekeningen info
19do ("$IP_pmPath") || die ("Cann't open $IP_pmPath");
20#slurp dns info
21#do ("$dnsheader_confPath") || die ("Cann't open $dnsheader_confPath");
22
23
24#zoek uit of het master_ip addr voorkomt in de configs
25#belangrijk van aliassen
26sub master_ipNotUsed {
27 if( $debug ) {
28 print "running master_ipNotUsed...\n";
29 }
30 foreach my $if (keys %config) {
31 if( $IP{$if} =~ /([0-9\.]+).*/ ) {
32 if( $1 eq $master_ip ) {
33 return(0);
34 };
35 };
36 };
37 return(1);
38};
39
40
41
42sub genHeader {
43 my $comment = $_[0];
44 my $output =
45 "$comment This file specific to wireless\n" .
46 "$comment leiden. Please make all changes in Genesis.\n" .
47 "$comment\n" .
48 "$comment Generated by $source\n" .
49 "$comment on $time\n" .
50 "$comment\n" .
51 "$comment $author\n" .
52 "$comment\n\n\n";
53 return ($output);
54};
55
56
57sub txtconfig {
58 my $output = "";
59 foreach $interface (keys %config) {
60 $output .= $config{$interface};
61 };
62 return($output);
63};
64
65
66sub dnsmasq_conf {
67 my $output = genHeader("#");
68 $output .=
69 "# DHCP server options \n" .
70 "dhcp-authoritative \n" .
71 "dhcp-fqdn \n" .
72 "domain=dhcp.$nodename.$domain. \n" .
73 "domain-needed \n" .
74 "expand-hosts \n" .
75 "\n" .
76 "# Low memory footprint \n" .
77 "cache-size=10000 \n" .
78 "\n";
79
80 foreach my $interface (sort keys %config) {
81 if( $interface =~ /^[a-z]+[0-9]+$/i ) {
82 (my $ip, my $netmask) = split('/', $IP{$interface});
83 my $subnet = IP::toSubnet($netmask);
84
85 $output .=
86 "## $interface $DESC{$interface}\n";
87
88 if ( $DHCP{$interface} =~ /[0-9]+\-[0-9]+/i ) {
89 my $dhcp_part = $ip;
90 $dhcp_part =~ s/[0-9]+$//;
91 (my $dhcp_start, my $dhcp_stop) = $DHCP{$interface} =~ /([0-9]+)\-([0-9]+)/i;
92 $dhcp_start = $dhcp_part . $dhcp_start;
93 $dhcp_stop = $dhcp_part . $dhcp_stop;
94 $output .= "dhcp-range=$interface,$dhcp_start,$dhcp_stop,$subnet,24h\n";
95 foreach my $dhcp_static (split(';', $DHCP_STATIC{$interface})) {
96 $output .= "dhcp-host=$dhcp_static\n";
97 };
98 $output .= "\n";
99 }
100 else {
101 $output .= "# not autoritive \n\n";
102 };
103
104 };
105 };
106
107 return($output);
108};
109
110
111sub dhcpd_conf {
112 my $output = genHeader("#");
113 $output .=
114 "option domain-name \"$domain\";\n" .
115 " \n" .
116 "default-lease-time 7200;\n" .
117 "max-lease-time 2592000;\n" .
118 "\n" .
119 "ddns-update-style none;\n" .
120 "\n" .
121 "# Hack for the WET11\n" .
122 "#\n" .
123 "always-broadcast on;\n" .
124 "\n" .
125 "option domain-name-servers ${master_ip};\n" .
126 "\n";
127
128 foreach my $interface (sort keys %config) {
129 if( $interface =~ /^[a-z]+[0-9]+$/i ) {
130 (my $ip, my $netmask) = split('/', $IP{$interface});
131 my $subnet = IP::toSubnet($netmask);
132 my $broadcast = IP::getBroadcastAddr($ip, $subnet);
133 my $network = IP::getNetworkAddr($ip, $subnet);
134
135 $output .=
136 "# $interface $DESC{$interface}\n";
137
138 if ( $DHCP{$interface} =~ /[0-9]+\-[0-9]+/i ) {
139 my $dhcp_part = $ip;
140 $dhcp_part =~ s/[0-9]+$//;
141 (my $dhcp_start, my $dhcp_stop) = $DHCP{$interface} =~ /([0-9]+)\-([0-9]+)/i;
142 $dhcp_start = $dhcp_part . $dhcp_start;
143 $dhcp_stop = $dhcp_part . $dhcp_stop;
144 $output .=
145 "subnet $network netmask $subnet {\n" .
146 " range $dhcp_start $dhcp_stop;\n" .
147 " option broadcast-address $broadcast;\n" .
148 " option subnet-mask $subnet;\n" .
149 " option routers $ip;\n" .
150 $DHCP_STATIC{$if} .
151 "}\n" .
152 "\n";
153 }
154 else {
155 $output .=
156 "subnet $network netmask $subnet {not authoritative; }\n" .
157 "\n";
158 };
159 };
160 };
161
162 return($output);
163};
164
165sub named_conf {
166 my $output = genHeader("#");
167 $output .=
168 "options {\n" .
169 " directory \"/etc/namedb\"\;\n" .
170 " pid-file \"/var/run/named/pid\"\;\n" .
171 " forwarders {\n";
172 foreach my $forward (@forwarder) {
173 $output .= "$forward;\n";
174 };
175 $output .=
176 " };\n" .
177 "};\n" .
178 "\n" .
179 "\n" .
180 "zone \"\.\" {\n" .
181 " type hint;\n" .
182 " file \"/etc/namedb/named.root\"\;\n" .
183 "}\;\n" .
184 "\n" .
185 "zone \"0\.0\.127\.IN-ADDR.ARPA\" {\n" .
186 " type master\;\n" .
187 " file \"/etc/namedb/master/localhost.rev\"\;\n" .
188 "}\;\n" .
189 "\n" .
190 "zone \"1.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.IP6.INT\" {\n" .
191 " type master\;\n" .
192 " file \"/etc/namedb/master/localhost-v6.rev\"\;\n" .
193 "};\n" .
194 "\n";
195
196
197 foreach my $tmpZone (sort keys %zone) {
198 my $dnsZone = $zone{$tmpZone};
199 $output .=
200 "zone \"$tmpZone\" {\n" .
201 " type slave\;\n" .
202 " file \"slave/slave-$tmpZone\"\;\n" .
203 " masters {\n";
204 foreach my $tmpIP (sort @$dnsZone) {
205 $output .= " $tmpIP\;\n";
206 };
207 $output .=
208 " };\n" .
209 "};\n" .
210 "\n";
211 };
212
213 return($output);
214};
215
216sub wleiden_conf {
217 # Generate our header
218 my $output = genHeader("#");
219
220 # Get al proxies
221 opendir(BIN, $ndir) or die "Can't open $dir: $!";
222 @proxyfiles = grep(/proxy/, readdir(BIN));
223 closedir(BIN);
224
225 # Walk through all our config files and get master_ip (and are up)
226 @proxies = ();
227 foreach $file (@proxyfiles) {
228 $nfile = "$ndir/$file/wleiden.conf";
229 parse_config($nfile);
230 if ($status == "up") {
231 $proxies[$proxyid] = $master_ip;
232 }
233 }
234
235 # Print the Ip's in shell variable script format
236 $output .= "PROXIES=`cat <<EOF\n";
237 foreach $ip (@proxies) {
238 if ($ip) {
239 $output .= "$ip\n";
240 }
241 }
242 $output .= "`\n";
243}
244
245sub rc_conf_local {
246 my $output = genHeader("#");
247 my $masterNotUsed = master_ipNotUsed();
248 $output.=
249 "hostname=\"$nodetype$nodename.$domain\"\n" .
250 "location=\"$location\"\n" .
251 "\n";
252
253 if( $tproxy ) {
254 if( $tproxy =~ m/\d+\.\d+\.\d+\.\d+\/\d+/ ) {
255 $output .=
256 "# Tproxy is ran on this system\n".
257 "tproxy_enable='YES'\n".
258 "tproxy_range='$tproxy'\n".
259 "\n";
260 }
261 elsif( $tproxy !~ m/no/i ) {
262 $output .= "# WARNING - specification propably wrong - check " .
263 "genesis. It should be a pure CIDR\n";
264 };
265 };
266
267 $iplist = "172.31.255.1/32";
268 if( $masterNotUsed ) {
269 $iplist .= " $master_ip/32";
270 }
271 $output .= "ipv4_addrs_lo0=\"127.0.0.1/8 $iplist\"\n";
272
273 @whitelist = ();
274 @dhcp_interfaces = ();
275 $WLAN_NR = 0;
276 foreach my $interface (sort keys %config) {
277 (my $if, my $number) = split(/:/, $interface);
278 if( not defined $number ) {
279 # No special syntax for aliases anymore
280 $IFNAME = $if;
281 if( $TYPE{$if} =~ /wireless/i ) {
282 $IFNAME = "wlan$WLAN_NR";
283 $WLAN_NR++;
284 $output .= "wlans_$if=\"$IFNAME\"\n";
285 $output .= "create_args_$IFNAME=\"";
286 if( $MODE{$if} =~/master/i ) {
287 $output .= "wlanmode ap";
288 } else {
289 $output .= "wlanmode sta"
290 }
291 if ( $SUBTYPE{$if} =~ /802.11a/i ) {
292 $output .= " mode 11a";
293 } elsif ( $SUBTYPE{$if} =~ /802.11g/i ) {
294 $output .= " mode 11g";
295 } else {
296 # Default output
297 $output .= " mode 11b";
298 }
299 $output .= " ssid $ESSID{$interface} regdomain ETSI country NL";
300 if( $MODE{$if} =~/master/i ) {
301 $output .= " channel $CHANNEL{$interface}";
302 }
303 if ( $CAPTIVE_PORTAL_WHITELIST{$if} ) {
304 push(@whitelist, $CAPTIVE_PORTAL_WHITELIST{$if});
305 }
306 if ($DHCP{$if} =~ /[0-9]+\-[0-9]+/i) {
307 push(@dhcp_interfaces, $IFNAME);
308 }
309 $output .= "\"\n";
310 }
311
312 @iplist = ();
313 foreach my $interface (sort keys %config) {
314 (my $if_t, my $number) = split(/:/, $interface);
315 if ( $if_t eq $if ) {
316 push(@iplist,$IP{$interface});
317 };
318 };
319 $output .= "ipv4_addrs_$IFNAME=\"" . join(' ',@iplist) . "\"\n";
320 $output .= "\n";
321 };
322 };
323 $output .= "\ncaptive_portal_whitelist=\"" .join(' ',@whitelist) . "\"\n";
324 $output .= "captive_portal_interfaces=\"" .join(' ',@dhcp_interfaces) . "\"\n";
325 return($output);
326};
327
328
329sub resolv_conf {
330 my $output = genHeader"#";
331
332 $output .=
333 "search wleiden.net\n" .
334 "# Try local (cache) first \n" .
335 "nameserver 127.0.0.1\n" .
336 "\n";
337
338 $output .=
339 "# proxies are also nameservers \n" .
340 "nameserver 172.17.8.68 # proxy1\n" .
341 "nameserver 172.17.143.4 # proxy2\n" .
342 "nameserver 172.20.128.98 # proxy3\n" .
343 "nameserver 172.16.2.254 # proxy4\n" .
344 "nameserver 172.19.168.66 # proxy5\n" .
345 "nameserver 172.16.3.146 # proxy6\n" .
346 "nameserver 172.17.16.66 # proxy62\n" .
347 "nameserver 172.17.0.1 # proxy7\n" .
348 "nameserver 172.16.4.54 # proxy9\n" .
349 "nameserver 172.22.0.66 # proxy10\n" .
350 "nameserver 172.23.25.66 # proxy11\n" .
351 "nameserver 172.17.169.66 # proxy97\n";
352
353 return($output);
354};
355
356
357sub parse_config {
358 my $workingfile = $_[0];
359 do($workingfile) || die("Cann't open/parse $workingfile");
360 foreach my $if (keys %config) {
361 my $cfg=$config{$if};
362 while ($cfg) {
363 $cfg=~s/^([^\n\r]+)[\r\n]*//m;
364 my $line=$1;
365 $line=~s/\s*#.*//;
366 if (((my $name, my $value)=split(/=/,$line)) eq 2) {
367 my $doit="if (exists(\$$name\{\"$if\"\})) {\$$name\{\"$if\"\}.=\";$value\";} else {\$$name\{\"$if\"\}.=\"$value\";}";
368 eval($doit);
369 };
370 $cfg=~s/[\r\n]*$//m;
371 };
372 };
373};
374
375sub authorized_keys {
376 my $output = genHeader("#");
377 if( -e "$global_keyPath" ) {
378 open( GLOBAL, "$global_keyPath" ) || die ("Cann't open $global_keyPath");
379 $output .= join("", <GLOBAL>);
380 close( GLOBAL );
381 }
382 else {
383 $output .= "# No $global_keyPath\n";
384 };
385
386 if( -e "$ndir/$nodetype$nodename/$ssh_file" ) {
387 open( NODE, "$ndir/$nodetype$nodename/$ssh_file" ) || die ("Cann't open $home/$nodename/$ssh_file");
388 $output .= join("", <NODE>);
389 close( NODE );
390 }
391 else {
392 $output .= "# No $ndir/$nodetype$nodename/$ssh_file\n";
393 };
394
395 return($output);
396};
397
398sub do_it {
399 my $file = $_[0];
400 my $body = "";
401
402 $file =~ s/\./_/g;
403 $body=&$file;
404 return($body);
405};
406
407if( exists $ARGV[0] ) {
408 if( exists $ARGV[1] ) {
409 parse_config($ARGV[0]);
410 print do_it($ARGV[1]);
411 }
412 else {
413 print "Usage `perl wleiden.pl 'inputfile' 'outputfile'`\n";
414 };
415};
416
4171;
Note: See TracBrowser for help on using the repository browser.