]>
Commit | Line | Data |
---|---|---|
27731caa CS |
1 | #!/usr/bin/perl |
2 | ############################################################################### | |
3 | # # | |
4 | # IPFire.org - A linux based firewall # | |
f89678de | 5 | # Copyright (C) 2007-2014 IPFire Team <info@ipfire.org> # |
27731caa CS |
6 | # # |
7 | # This program is free software: you can redistribute it and/or modify # | |
8 | # it under the terms of the GNU General Public License as published by # | |
9 | # the Free Software Foundation, either version 3 of the License, or # | |
10 | # (at your option) any later version. # | |
11 | # # | |
12 | # This program is distributed in the hope that it will be useful, # | |
13 | # but WITHOUT ANY WARRANTY; without even the implied warranty of # | |
14 | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # | |
15 | # GNU General Public License for more details. # | |
16 | # # | |
17 | # You should have received a copy of the GNU General Public License # | |
18 | # along with this program. If not, see <http://www.gnu.org/licenses/>. # | |
19 | # # | |
20 | ############################################################################### | |
21 | # | |
22 | # WLAN AP cgi based on wlanap.cgi written by Markus Hoffmann & Olaf Westrik | |
23 | # | |
24 | ||
25 | use strict; | |
26 | ||
27 | # enable only the following on debugging purpose | |
8aa49c15 CS |
28 | #use warnings; |
29 | #use CGI::Carp 'fatalsToBrowser'; | |
27731caa CS |
30 | |
31 | require '/var/ipfire/general-functions.pl'; | |
32 | require '/var/ipfire/lang.pl'; | |
33 | require '/var/ipfire/header.pl'; | |
34 | ||
35 | my $debug = 0; | |
8c2f203c | 36 | my $status = ''; |
27731caa | 37 | my $errormessage = ''; |
3827d1f6 AM |
38 | my $status_started = "<td align='center' bgcolor='${Header::colourgreen}'><font color='white'><strong>$Lang::tr{'running'}</strong></font></td>"; |
39 | my $status_stopped = "<td align='center' bgcolor='${Header::colourred}'><font color='white'><strong>$Lang::tr{'stopped'}</strong></font></td>"; | |
40 | my $count=0; | |
41 | my $col=''; | |
27731caa CS |
42 | # get rid of used only once warnings |
43 | my @onlyonce = ( $Header::colourgreen, $Header::colourred ); | |
44 | undef @onlyonce; | |
45 | ||
46 | my %selected=(); | |
47 | my %checked=(); | |
48 | my %color = (); | |
49 | my %mainsettings = (); | |
54359730 CS |
50 | my %netsettings=(); |
51 | my %wlanapsettings=(); | |
27731caa | 52 | my $channel = ''; |
c3d9a16d | 53 | my $country = ''; |
27731caa CS |
54 | my $txpower = ''; |
55 | ||
56 | &General::readhash("${General::swroot}/main/settings", \%mainsettings); | |
8186b372 | 57 | &General::readhash("/srv/web/ipfire/html/themes/ipfire/include/colors.txt", \%color); |
54359730 | 58 | &General::readhash("/var/ipfire/ethernet/settings", \%netsettings); |
27731caa | 59 | |
27731caa | 60 | $wlanapsettings{'APMODE'} = 'on'; |
23e368ab | 61 | $wlanapsettings{'ACTION'} = ''; |
92f2665d CS |
62 | $wlanapsettings{'MACMODE'} = '0'; |
63 | $wlanapsettings{'INTERFACE'} = ''; | |
27731caa CS |
64 | $wlanapsettings{'SSID'} = 'IPFire'; |
65 | $wlanapsettings{'HIDESSID'} = 'off'; | |
91197a3f | 66 | $wlanapsettings{'ENC'} = 'wpa2'; # none / wpa1 /wpa2 |
27731caa | 67 | $wlanapsettings{'TXPOWER'} = 'auto'; |
2bb836df | 68 | $wlanapsettings{'CHANNEL'} = '6'; |
c3d9a16d | 69 | $wlanapsettings{'COUNTRY'} = '00'; |
7d30ef24 | 70 | $wlanapsettings{'HW_MODE'} = 'g'; |
27731caa | 71 | $wlanapsettings{'PWD'} = 'IPFire-2.x'; |
27731caa CS |
72 | $wlanapsettings{'SYSLOGLEVEL'} = '0'; |
73 | $wlanapsettings{'DEBUG'} = '4'; | |
c17883fd | 74 | $wlanapsettings{'DRIVER'} = 'NL80211'; |
6e346fe0 | 75 | $wlanapsettings{'HTCAPS'} = ''; |
f887bf5f | 76 | $wlanapsettings{'VHTCAPS'} = ''; |
d823d5f0 | 77 | $wlanapsettings{'NOSCAN'} = 'off'; |
5b4464a9 | 78 | $wlanapsettings{'CLIENTISOLATION'} = 'off'; |
37a83c83 | 79 | $wlanapsettings{'IEEE80211W'} = 'off'; |
27731caa | 80 | |
27731caa | 81 | &General::readhash("/var/ipfire/wlanap/settings", \%wlanapsettings); |
23e368ab | 82 | &Header::getcgihash(\%wlanapsettings); |
27731caa | 83 | |
23e368ab | 84 | my @macs = $wlanapsettings{'MACS'}; |
27731caa | 85 | |
23e368ab CS |
86 | delete $wlanapsettings{'__CGI__'}; |
87 | delete $wlanapsettings{'x'}; | |
88 | delete $wlanapsettings{'y'}; | |
89 | delete $wlanapsettings{'MACS'}; | |
90 | delete $wlanapsettings{'ACCEPT_MACS'}; | |
91 | delete $wlanapsettings{'DENY_MACS'}; | |
27731caa CS |
92 | |
93 | &Header::showhttpheaders(); | |
94 | ||
182a817a JPT |
95 | my $string=(); |
96 | my $status=(); | |
97 | my $errormessage = ''; | |
98 | my $memory = 0; | |
99 | my @memory=(); | |
100 | my @pid=(); | |
101 | my @hostapd=(); | |
102 | sub pid | |
103 | { | |
104 | # for pid and memory | |
105 | open(FILE, '/usr/local/bin/addonctrl hostapd status | '); | |
106 | @hostapd = <FILE>; | |
107 | close(FILE); | |
108 | $string = join("", @hostapd); | |
109 | $string =~ s/[a-z_]//gi; | |
110 | $string =~ s/\[[0-1]\;[0-9]+//gi; | |
111 | $string =~ s/[\(\)\.]//gi; | |
112 | $string =~ s/ //gi; | |
113 | $string =~ s/\e//gi; | |
114 | @pid = split(/\s/,$string); | |
115 | if (open(FILE, "/proc/$pid[0]/statm")){ | |
116 | my $temp = <FILE>; | |
117 | @memory = split(/ /,$temp); | |
118 | close(FILE); | |
119 | } | |
120 | $memory+=$memory[0]; | |
121 | } | |
122 | pid(); | |
123 | ||
124 | ||
125 | ||
126 | if ( $wlanapsettings{'ACTION'} eq "$Lang::tr{'wlanap del interface'}" ){ | |
127 | delete $wlanapsettings{'INTERFACE'}; | |
128 | &General::writehash("/var/ipfire/wlanap/settings", \%wlanapsettings); | |
129 | } | |
130 | ||
23e368ab | 131 | if ( $wlanapsettings{'ACTION'} eq "$Lang::tr{'save'}" ){ |
3af89eb5 | 132 | # verify WPA Passphrase - only with enabled enc |
f832c758 | 133 | if ($wlanapsettings{'ENC'} ne "none") { |
3af89eb5 | 134 | # must be 8 .. 63 characters |
182a817a JPT |
135 | if ( (length($wlanapsettings{'PWD'}) < 8) || (length($wlanapsettings{'PWD'}) > 63)){ |
136 | $errormessage .= "$Lang::tr{'wlanap invalid wpa'}<br />"; | |
137 | } | |
3af89eb5 | 138 | # only ASCII alowed |
cdbeabe2 | 139 | if ( !($wlanapsettings{'PWD'} !~ /[^\x00-\x7f]/) ){ |
3af89eb5 AF |
140 | $errormessage .= "$Lang::tr{'wlanap invalid wpa'}<br />"; |
141 | } | |
27731caa CS |
142 | } |
143 | ||
144 | if ( $errormessage eq '' ){ | |
92f2665d | 145 | &General::writehash("/var/ipfire/wlanap/settings", \%wlanapsettings); |
27731caa CS |
146 | &WriteConfig_hostapd(); |
147 | ||
91197a3f | 148 | system("/usr/local/bin/wlanapctrl restart >/dev/null 2>&1"); |
182a817a | 149 | pid(); |
27731caa | 150 | } |
182a817a | 151 | }elsif ( $wlanapsettings{'ACTION'} eq "$Lang::tr{'wlanap interface'}" ){ |
92f2665d | 152 | &General::writehash("/var/ipfire/wlanap/settings", \%wlanapsettings); |
182a817a | 153 | }elsif ( ($wlanapsettings{'ACTION'} eq "$Lang::tr{'start'}") && ($memory == 0) ){ |
27731caa | 154 | system("/usr/local/bin/wlanapctrl start >/dev/null 2>&1"); |
182a817a JPT |
155 | pid(); |
156 | }elsif ( $wlanapsettings{'ACTION'} eq "$Lang::tr{'stop'}" ){ | |
27731caa | 157 | system("/usr/local/bin/wlanapctrl stop >/dev/null 2>&1"); |
182a817a | 158 | $memory=0; |
27731caa CS |
159 | } |
160 | ||
d3790c6a | 161 | &Header::openpage($Lang::tr{'wlanap configuration'}, 1, '', ''); |
27731caa | 162 | &Header::openbigbox('100%', 'left', '', $errormessage); |
27731caa CS |
163 | |
164 | if ( $errormessage ){ | |
54359730 | 165 | &Header::openbox('100%', 'center', $Lang::tr{'error messages'}); |
27731caa CS |
166 | print "<class name='base'>$errormessage\n"; |
167 | print " </class>\n"; | |
168 | &Header::closebox(); | |
169 | } | |
170 | ||
171 | ||
172 | # Found this usefull piece of code in BlockOutTraffic AddOn 8-) | |
173 | # fwrules.cgi | |
174 | ############### | |
175 | # DEBUG DEBUG | |
176 | if ( $debug ){ | |
54359730 | 177 | &Header::openbox('100%', 'center', 'DEBUG'); |
27731caa | 178 | my $debugCount = 0; |
23e368ab CS |
179 | foreach my $line (sort keys %wlanapsettings) { |
180 | print "$line = '$wlanapsettings{$line}'<br />\n"; | |
27731caa CS |
181 | $debugCount++; |
182 | } | |
183 | print " Count: $debugCount\n"; | |
184 | &Header::closebox(); | |
185 | } | |
186 | # DEBUG DEBUG | |
187 | ############### | |
188 | ||
189 | # | |
190 | # Driver and status detection | |
191 | # | |
192 | my $wlan_card_status = 'dummy'; | |
193 | my $wlan_ap_status = ''; | |
92f2665d CS |
194 | my $message = ""; |
195 | ||
196 | $selected{'INTERFACE'}{'green0'} = ''; | |
197 | $selected{'INTERFACE'}{'blue0'} = ''; | |
198 | $selected{'ENC'}{$wlanapsettings{'INTERFACE'}} = "selected='selected'"; | |
27731caa | 199 | |
92f2665d | 200 | if ( ($wlanapsettings{'INTERFACE'} eq '') ){ |
182a817a | 201 | $message = $Lang::tr{'wlanap select interface'}; |
92f2665d CS |
202 | &Header::openbox('100%', 'center', "WLAN AP"); |
203 | print <<END | |
204 | $message<br /> | |
205 | <form method='post' action='$ENV{'SCRIPT_NAME'}'> | |
206 | <select name='INTERFACE'> | |
92f2665d CS |
207 | END |
208 | ; | |
209 | if ( $netsettings{'BLUE_DEV'} ne ''){ | |
210 | print "<option value='blue0' $selected{'INTERFACE'}{'blue0'}>blue0</option>"; | |
211 | } | |
212 | print <<END | |
182a817a | 213 | <option value='green0' $selected{'INTERFACE'}{'green0'}>green0</option> |
92f2665d | 214 | </select> |
182a817a JPT |
215 | <br /><br /> |
216 | <hr size='1'> | |
217 | <input type='submit' name='ACTION' value='$Lang::tr{'wlanap interface'}' /></form> | |
92f2665d CS |
218 | END |
219 | ; | |
220 | &Header::closebox(); | |
221 | &Header::closebigbox(); | |
222 | &Header::closepage(); | |
223 | exit; | |
27731caa | 224 | }else{ |
92f2665d | 225 | my $cmd_out = `/usr/sbin/iwconfig $wlanapsettings{'INTERFACE'} 2>/dev/null`; |
27731caa CS |
226 | |
227 | if ( $cmd_out eq '' ){ | |
182a817a | 228 | $message = "$Lang::tr{'wlanap no interface'}"; |
92f2665d | 229 | $wlan_card_status = ''; |
27731caa | 230 | }else{ |
92f2665d | 231 | $cmd_out = `/sbin/ifconfig | /bin/grep $wlanapsettings{'INTERFACE'}`; |
27731caa CS |
232 | if ( $cmd_out eq '' ){ |
233 | $wlan_card_status = 'down'; | |
234 | }else{ | |
235 | $wlan_card_status = 'up'; | |
92f2665d | 236 | $cmd_out = `/usr/sbin/iwconfig $wlanapsettings{'INTERFACE'} | /bin/grep "Mode:Master"`; |
27731caa CS |
237 | if ( $cmd_out ne '' ){ |
238 | $wlan_ap_status = 'up'; | |
27731caa CS |
239 | } |
240 | } | |
241 | } | |
242 | } | |
243 | ||
e62efbb7 AF |
244 | # Change old "n" to "gn" |
245 | if ( $wlanapsettings{'HW_MODE'} eq 'n' ) { | |
246 | $wlanapsettings{'HW_MODE'}='gn'; | |
247 | } | |
248 | ||
b8990355 CS |
249 | $checked{'HIDESSID'}{'off'} = ''; |
250 | $checked{'HIDESSID'}{'on'} = ''; | |
251 | $checked{'HIDESSID'}{$wlanapsettings{'HIDESSID'}} = "checked='checked'"; | |
27731caa | 252 | |
d823d5f0 AF |
253 | $checked{'NOSCAN'}{'off'} = ''; |
254 | $checked{'NOSCAN'}{'on'} = ''; | |
255 | $checked{'NOSCAN'}{$wlanapsettings{'NOSCAN'}} = "checked='checked'"; | |
256 | ||
5b4464a9 PM |
257 | $checked{'CLIENTISOLATION'}{'off'} = ''; |
258 | $checked{'CLIENTISOLATION'}{'on'} = ''; | |
259 | $checked{'CLIENTISOLATION'}{$wlanapsettings{'CLIENTISOLATION'}} = "checked='checked'"; | |
260 | ||
13cbb92a MT |
261 | $selected{'IEEE80211W'}{'off'} = ''; |
262 | $selected{'IEEE80211W'}{'optional'} = ''; | |
263 | $selected{'IEEE80211W'}{'on'} = ''; | |
264 | $selected{'IEEE80211W'}{$wlanapsettings{'IEEE80211W'}} = "selected"; | |
37a83c83 | 265 | |
27731caa | 266 | $selected{'ENC'}{$wlanapsettings{'ENC'}} = "selected='selected'"; |
30313f28 | 267 | $selected{'CHANNEL'}{$wlanapsettings{'CHANNEL'}} = "selected='selected'"; |
c3d9a16d | 268 | $selected{'COUNTRY'}{$wlanapsettings{'COUNTRY'}} = "selected='selected'"; |
54359730 | 269 | $selected{'TXPOWER'}{$wlanapsettings{'TXPOWER'}} = "selected='selected'"; |
7d30ef24 | 270 | $selected{'HW_MODE'}{$wlanapsettings{'HW_MODE'}} = "selected='selected'"; |
92f2665d | 271 | $selected{'MACMODE'}{$wlanapsettings{'MACMODE'}} = "selected='selected'"; |
27731caa | 272 | |
c3d9a16d | 273 | my $monwlaninterface = $wlanapsettings{'INTERFACE'}; |
56c2cc65 | 274 | if ( -d '/sys/class/net/mon.'.$wlanapsettings{'INTERFACE'} ) { |
c3d9a16d AF |
275 | $monwlaninterface = 'mon.'.$wlanapsettings{'INTERFACE'}; |
276 | } | |
277 | ||
0f0d6a5a | 278 | my @channellist_cmd; |
ea10f1a0 | 279 | my @channellist = (0); |
0f0d6a5a AF |
280 | |
281 | if ( $wlanapsettings{'DRIVER'} eq 'NL80211' ){ | |
282 | my $wiphy = `iw dev $wlanapsettings{'INTERFACE'} info | grep wiphy | cut -d" " -f2`; | |
283 | chomp $wiphy; | |
284 | ||
05583186 | 285 | @channellist_cmd = `iw phy phy$wiphy info | grep " MHz \\\[" | grep -v "(disabled)" | grep -v "no IBSS" | grep -v "no IR" | grep -v "passive scanning" 2>/dev/null`; |
0f0d6a5a AF |
286 | # get available channels |
287 | ||
288 | my @temp; | |
289 | foreach (@channellist_cmd){ | |
290 | $_ =~ /(.*) \[(\d+)(.*)\]/; | |
291 | $channel = $2;chomp $channel; | |
12f74b8f | 292 | if ( $channel =~ /\d+/ ){push(@temp,$channel + 0);} |
0f0d6a5a | 293 | } |
ea10f1a0 | 294 | push(@channellist, @temp); |
0f0d6a5a AF |
295 | } else { |
296 | @channellist_cmd = `iwlist $monwlaninterface channel|tail -n +2 2>/dev/null`; | |
27731caa | 297 | # get available channels |
27731caa | 298 | |
54359730 | 299 | my @temp; |
8c2f203c | 300 | foreach (@channellist_cmd){ |
54359730 | 301 | $_ =~ /(.*)Channel (\d+)(.*):/; |
8c2f203c | 302 | $channel = $2;chomp $channel; |
12f74b8f | 303 | if ( $channel =~ /\d+/ ){push(@temp,$channel + 0);} |
27731caa | 304 | } |
ea10f1a0 | 305 | push(@channellist, @temp); |
0f0d6a5a | 306 | } |
54359730 | 307 | |
c3d9a16d AF |
308 | my @countrylist_cmd = `regdbdump /usr/lib/crda/regulatory.bin 2>/dev/null`; |
309 | # get available country codes | |
310 | ||
8e23b351 | 311 | my @temp = "00"; |
c3d9a16d AF |
312 | foreach (@countrylist_cmd){ |
313 | $_ =~ /country (.*):/; | |
314 | $country = $1;chomp $country; | |
315 | if ( $country =~ /[0,A-Z][0,A-Z]/ ) {push(@temp,$country);} | |
316 | } | |
317 | my @countrylist = @temp; | |
318 | ||
319 | my @txpower_cmd = `iwlist $monwlaninterface txpower 2>/dev/null`; | |
320 | if ( $wlanapsettings{'DRIVER'} eq 'NL80211' ){ | |
321 | # There is a bug with NL80211 only all devices can displayed | |
322 | @txpower_cmd = `iwlist txpower 2>/dev/null | sed -e "s|unknown transmit-power information.||g"`; | |
323 | } | |
324 | # get available power | |
27731caa | 325 | |
27731caa | 326 | $selected{'SYSLOGLEVEL'}{$wlanapsettings{'SYSLOGLEVEL'}} = "selected='selected'"; |
27731caa CS |
327 | $selected{'DEBUG'}{$wlanapsettings{'DEBUG'}} = "selected='selected'"; |
328 | ||
329 | # | |
330 | # Status box | |
331 | # | |
54359730 | 332 | &Header::openbox('100%', 'center', "WLAN AP"); |
27731caa | 333 | print <<END |
3827d1f6 | 334 | <table width='80%' cellspacing='1' class='tbl'> |
27731caa CS |
335 | END |
336 | ; | |
182a817a | 337 | |
27731caa | 338 | if ( $wlan_card_status ne '' ){ |
3827d1f6 AM |
339 | print "<tr><th align='left' width='50%'><strong>$Lang::tr{'service'}</strong></th><th width='22%'>Status</th><th width='10%'>PID</th><th width='15%'>$Lang::tr{'memory'}</th><th colspan='2'width='5%'>$Lang::tr{'action'}</th></tr>"; |
340 | print "<tr><td class='base'>$Lang::tr{'wlanap wlan card'} ($wlanapsettings{'DRIVER'})</td>"; | |
27731caa | 341 | print $wlan_card_status eq 'up' ? $status_started : $status_stopped; |
3827d1f6 | 342 | print"<td colspan='4'></td></tr>"; |
d3790c6a | 343 | print "<tr><td class='base' bgcolor='$color{'color22'}'>$Lang::tr{'wlanap'}</td>"; |
27731caa | 344 | print $wlan_ap_status eq 'up' ? $status_started : $status_stopped; |
3827d1f6 AM |
345 | if ( ($memory != 0) && (@pid[0] ne "///") ){ |
346 | print "<td bgcolor='$color{'color22'}' align='center'>@pid[0]</td>"; | |
347 | print "<td bgcolor='$color{'color22'}' align='center'>$memory KB</td>"; | |
348 | print "<td bgcolor='$color{'color22'}'><form method='post' action='$ENV{'SCRIPT_NAME'}'><input type='hidden' name='ACTION' value='$Lang::tr{'start'}' /><input type='image' alt='$Lang::tr{'start'}' title='$Lang::tr{'start'}' src='/images/go-up.png' /></form></td>"; | |
349 | print "<td bgcolor='$color{'color22'}'><form method='post' action='$ENV{'SCRIPT_NAME'}'><input type='hidden' name='ACTION' value='$Lang::tr{'stop'}' /><input type='image' alt='$Lang::tr{'stop'}' title='$Lang::tr{'stop'}' src='/images/go-down.png' /></form></td>"; | |
350 | }else{ | |
351 | print"<td colspan='2' bgcolor='$color{'color22'}'></td>"; | |
352 | print "<td bgcolor='$color{'color22'}'><form method='post' action='$ENV{'SCRIPT_NAME'}'><input type='hidden' name='ACTION' value='$Lang::tr{'start'}' /><input type='image' alt='$Lang::tr{'start'}' title='$Lang::tr{'start'}' src='/images/go-up.png' /></form></td>"; | |
353 | print "<td bgcolor='$color{'color22'}'><form method='post' action='$ENV{'SCRIPT_NAME'}'><input type='hidden' name='ACTION' value='$Lang::tr{'stop'}' /><input type='image' alt='$Lang::tr{'stop'}' title='$Lang::tr{'stop'}' src='/images/go-down.png' /></form></td>"; | |
354 | } | |
182a817a | 355 | |
27731caa | 356 | }else{ |
3827d1f6 | 357 | print "<tr><td class='base'>$message"; |
182a817a JPT |
358 | } |
359 | print "</table>"; | |
360 | ||
3827d1f6 AM |
361 | if ( $wlan_card_status eq '' ){ |
362 | print "<br />"; | |
363 | print "<table width='80%' cellspacing='0' border='0'>"; | |
364 | print "<tr align='center'>"; | |
365 | print "<td colspan='4'></td>"; | |
182a817a | 366 | print "</tr>"; |
3827d1f6 AM |
367 | print "<tr align='center'>"; |
368 | print "<td width='40%'> </td>"; | |
369 | print "<td width='20%'><form method='post' action='/cgi-bin/wlanap.cgi'><input type='submit' name='ACTION' value='$Lang::tr{'wlanap del interface'}' /></form></td>"; | |
370 | print "<td width='20%'></td>"; | |
371 | print "<td width='20%'></td>"; | |
182a817a JPT |
372 | print "</tr>"; |
373 | print "</table>"; | |
27731caa | 374 | } |
27731caa CS |
375 | |
376 | if ( $wlan_card_status eq '' ){ | |
92f2665d | 377 | &Header::closebox(); |
27731caa CS |
378 | &Header::closebigbox(); |
379 | &Header::closepage(); | |
380 | exit 0; | |
381 | } | |
27731caa | 382 | print <<END |
3827d1f6 | 383 | <br><br> |
23e368ab | 384 | <form method='post' action='$ENV{'SCRIPT_NAME'}'> |
3827d1f6 AM |
385 | <table width='80%' cellspacing='0' class='tbl' border='0'> |
386 | <tr><th bgcolor='$color{'color20'}' colspan='4' align='left'><strong>$Lang::tr{'wlanap wlan settings'}</strong></th></tr> | |
387 | <tr><td colspan='4'><br></td></tr> | |
c7217140 | 388 | <tr><td width='25%' class='base'>$Lang::tr{'wlanap ssid'}: </td><td class='base' colspan='3'><input type='text' name='SSID' size='30' value='$wlanapsettings{'SSID'}' /></td></tr> |
0d4e628e | 389 | <!--SSID Broadcast: on => HIDESSID: off --> |
c7217140 MT |
390 | <tr><td width='25%' class='base'>$Lang::tr{'wlanap broadcast ssid'}: </td><td class='base' colspan='3'>$Lang::tr{'on'} <input type='radio' name='HIDESSID' value='off' $checked{'HIDESSID'}{'off'} /> | <input type='radio' name='HIDESSID' value='on' $checked{'HIDESSID'}{'on'} /> $Lang::tr{'off'}</td></tr> |
391 | <tr><td width='25%' class='base'>$Lang::tr{'wlanap client isolation'}: </td><td class='base' colspan='3'>$Lang::tr{'on'} <input type='radio' name='CLIENTISOLATION' value='on' $checked{'CLIENTISOLATION'}{'on'} /> | <input type='radio' name='CLIENTISOLATION' value='off' $checked{'CLIENTISOLATION'}{'off'} /> $Lang::tr{'off'}</td></tr> | |
3827d1f6 AM |
392 | <tr><td width='25%' class='base'>$Lang::tr{'wlanap country'}: </td><td class='base' colspan='3'> |
393 | <select name='COUNTRY'> | |
394 | END | |
395 | ; | |
396 | foreach $country (@countrylist){ | |
397 | print "<option $selected{'COUNTRY'}{$country}>$country</option>"; | |
398 | } | |
399 | print<<END | |
400 | </select></td></tr> | |
7d30ef24 AF |
401 | <tr><td width='25%' class='base'>HW Mode: </td><td class='base' colspan='3'> |
402 | <select name='HW_MODE'> | |
182a817a JPT |
403 | <option value='a' $selected{'HW_MODE'}{'a'}>802.11a</option> |
404 | <option value='b' $selected{'HW_MODE'}{'b'}>802.11b</option> | |
405 | <option value='g' $selected{'HW_MODE'}{'g'}>802.11g</option> | |
e62efbb7 AF |
406 | <option value='an' $selected{'HW_MODE'}{'an'}>802.11an</option> |
407 | <option value='gn' $selected{'HW_MODE'}{'gn'}>802.11gn</option> | |
f887bf5f | 408 | <option value='ac' $selected{'HW_MODE'}{'ac'}>802.11ac</option> |
7d30ef24 AF |
409 | </select> |
410 | </td></tr> | |
fe3f3050 AF |
411 | END |
412 | ; | |
413 | ||
fe3f3050 AF |
414 | if ( scalar @channellist > 0 ){ |
415 | print <<END | |
182a817a | 416 | <tr><td width='25%' class='base'>$Lang::tr{'wlanap channel'}: </td><td class='base' colspan='3'> |
30313f28 | 417 | <select name='CHANNEL'> |
27731caa CS |
418 | END |
419 | ; | |
fe3f3050 | 420 | foreach $channel (@channellist){ |
ea10f1a0 MT |
421 | print "<option $selected{'CHANNEL'}{$channel}>"; |
422 | if ($channel eq 0) { | |
423 | print "- $Lang::tr{'wlanap auto'} -"; | |
424 | } else { | |
425 | print $channel; | |
426 | } | |
427 | print "</option>"; | |
fe3f3050 AF |
428 | } |
429 | print "</select></td></tr>" | |
430 | } else { | |
431 | print <<END | |
432 | <tr><td width='25%' class='base'>$Lang::tr{'wlanap channel'}: </td><td class='base' colspan='3'> | |
433 | <input type='text' name='CHANNEL' size='10' value='$wlanapsettings{'CHANNEL'}' /> | |
434 | </td></tr> | |
435 | END | |
436 | ; | |
27731caa | 437 | } |
3827d1f6 | 438 | print<<END |
fd1b46f1 | 439 | <tr><td width='25%' class='base'>$Lang::tr{'wlanap neighbor scan'}: </td><td class='base' >$Lang::tr{'on'} <input type='radio' name='NOSCAN' value='off' $checked{'NOSCAN'}{'off'} /> | <input type='radio' name='NOSCAN' value='on' $checked{'NOSCAN'}{'on'} /> $Lang::tr{'off'}</td><td class='base' colspan='2'>$Lang::tr{'wlanap neighbor scan warning'}</td></tr> |
3827d1f6 AM |
440 | <tr><td colspan='4'><br></td></tr> |
441 | <tr><td width='25%' class='base'>$Lang::tr{'wlanap encryption'}: </td><td class='base' colspan='3'> | |
442 | <select name='ENC'> | |
443 | <option value='none' $selected{'ENC'}{'none'}>$Lang::tr{'wlanap none'}</option> | |
444 | <option value='wpa1' $selected{'ENC'}{'wpa1'}>WPA1</option> | |
445 | <option value='wpa2' $selected{'ENC'}{'wpa2'}>WPA2</option> | |
f832c758 | 446 | <option value='wpa3' $selected{'ENC'}{'wpa3'}>WPA3</option> |
3827d1f6 | 447 | <option value='wpa1+2' $selected{'ENC'}{'wpa1+2'}>WPA1+2</option> |
f832c758 | 448 | <option value='wpa2+3' $selected{'ENC'}{'wpa2+3'}>WPA2+3</option> |
3827d1f6 AM |
449 | </select> |
450 | </td></tr> | |
451 | <tr><td width='25%' class='base'>Passphrase: </td><td class='base' colspan='3'><input type='text' name='PWD' size='30' value='$wlanapsettings{'PWD'}' /></td></tr> | |
37a83c83 MT |
452 | <tr> |
453 | <td width='25%' class='base'>$Lang::tr{'wlanap management frame protection'}: </td> | |
454 | <td class='base' colspan="3"> | |
13cbb92a MT |
455 | <select name="IEEE80211W"> |
456 | <option value="off" $selected{'IEEE80211W'}{'off'}>$Lang::tr{'wlanap 802.11w disabled'}</option> | |
457 | <option value="optional" $selected{'IEEE80211W'}{'optional'}>$Lang::tr{'wlanap 802.11w optional'}</option> | |
458 | <option value="on" $selected{'IEEE80211W'}{'on'}>$Lang::tr{'wlanap 802.11w enforced'}</option> | |
459 | </select> | |
37a83c83 MT |
460 | </td> |
461 | </tr> | |
3827d1f6 | 462 | <tr><td colspan='4'><br></td></tr> |
c3d9a16d AF |
463 | END |
464 | ; | |
27731caa | 465 | print <<END |
3827d1f6 | 466 | <tr><td width='25%' class='base'>HT Caps: </td><td class='base' colspan='3'><input type='text' name='HTCAPS' size='30' value='$wlanapsettings{'HTCAPS'}' /></td></tr> |
f887bf5f | 467 | <tr><td width='25%' class='base'>VHT Caps: </td><td class='base' colspan='3'><input type='text' name='VHTCAPS' size='30' value='$wlanapsettings{'VHTCAPS'}' /></td></tr> |
c17883fd | 468 | <tr><td width='25%' class='base'>Tx Power: </td><td class='base' colspan='3'><input type='text' name='TXPOWER' size='10' value='$wlanapsettings{'TXPOWER'}' /></td></tr> |
27731caa CS |
469 | <tr><td width='25%' class='base'>Loglevel (hostapd): </td><td class='base' width='25%'> |
470 | <select name='SYSLOGLEVEL'> | |
182a817a JPT |
471 | <option value='0' $selected{'SYSLOGLEVEL'}{'0'}>0 ($Lang::tr{'wlanap verbose'})</option> |
472 | <option value='1' $selected{'SYSLOGLEVEL'}{'1'}>1 ($Lang::tr{'wlanap debugging'})</option> | |
473 | <option value='2' $selected{'SYSLOGLEVEL'}{'2'}>2 ($Lang::tr{'wlanap informations'})</option> | |
474 | <option value='3' $selected{'SYSLOGLEVEL'}{'3'}>3 ($Lang::tr{'wlanap notifications'})</option> | |
475 | <option value='4' $selected{'SYSLOGLEVEL'}{'4'}>4 ($Lang::tr{'wlanap warnings'})</option> | |
27731caa CS |
476 | </select> |
477 | </td> | |
478 | <td width='25%' class='base'>Debuglevel (hostapd): </td><td class='base' width='25%'> | |
479 | <select name='DEBUG'> | |
182a817a JPT |
480 | <option value='0' $selected{'DEBUG'}{'0'}>0 ($Lang::tr{'wlanap verbose'})</option> |
481 | <option value='1' $selected{'DEBUG'}{'1'}>1 ($Lang::tr{'wlanap debugging'})</option> | |
482 | <option value='2' $selected{'DEBUG'}{'2'}>2 ($Lang::tr{'wlanap informations'})</option> | |
483 | <option value='3' $selected{'DEBUG'}{'3'}>3 ($Lang::tr{'wlanap notifications'})</option> | |
484 | <option value='4' $selected{'DEBUG'}{'4'}>4 ($Lang::tr{'wlanap warnings'})</option> | |
27731caa CS |
485 | </select> |
486 | </td></tr> | |
3827d1f6 | 487 | <tr><td colspan='4'><br></td></tr> |
27731caa | 488 | </table> |
92f2665d CS |
489 | END |
490 | ; | |
491 | if ( $wlanapsettings{'INTERFACE'} =~ /green0/ ){ | |
492 | print <<END | |
493 | <br /> | |
3827d1f6 AM |
494 | <table width='80%' cellspacing='0' class='tbl' border='1'> |
495 | <tr> | |
496 | <th colspan='3' align='left'>$Lang::tr{'mac filter'}</th> | |
497 | </tr> | |
92f2665d CS |
498 | <td width='25%' class='base'>Mac Filter: </td><td class='base' width='25%'> |
499 | <select name='MACMODE'> | |
500 | <option value='0' $selected{'MACMODE'}{'0'}>0 (off)</option> | |
8aa49c15 CS |
501 | <option value='1' $selected{'MACMODE'}{'1'}>1 (Accept MACs)</option> |
502 | <option value='2' $selected{'MACMODE'}{'2'}>2 (Deny MACs)</option> | |
92f2665d | 503 | </select> |
8aa49c15 | 504 | </td><td colspan='2'>Mac Adress List (one per line)<br /><textarea name='MACS' cols='20' rows='5' wrap='off'> |
92f2665d CS |
505 | END |
506 | ; | |
8aa49c15 | 507 | print `cat /var/ipfire/wlanap/macfile`; |
92f2665d CS |
508 | print <<END |
509 | </textarea></td> | |
92f2665d CS |
510 | </table> |
511 | END | |
512 | ; | |
513 | } | |
514 | print <<END | |
54359730 | 515 | <br /> |
3827d1f6 | 516 | <table width='80%' cellspacing='0'> |
735fce60 | 517 | <tr><td align='center'> |
182a817a | 518 | <form method='post' action='$ENV{'SCRIPT_NAME'}'> |
ed7f8152 | 519 | <input type='submit' name='ACTION' value='$Lang::tr{'save'}' /></form></td> |
27731caa CS |
520 | </tr> |
521 | </table> | |
522 | END | |
523 | ; | |
0f0d6a5a | 524 | my @status; |
7d30ef24 | 525 | if ( $wlanapsettings{'DRIVER'} eq 'NL80211' ){ |
513c321e | 526 | @status = `iw dev $wlanapsettings{'INTERFACE'} info && iw dev $wlanapsettings{'INTERFACE'} station dump && echo ""`; |
7d30ef24 | 527 | } |
54359730 CS |
528 | print <<END |
529 | <br /> | |
3827d1f6 AM |
530 | <table width='80%' cellspacing='0' class='tbl'> |
531 | <tr><th colspan='3' bgcolor='$color{'color20'}' align='left'><strong>$Lang::tr{'wlanap wlan status'}</strong></th></tr> | |
532 | END | |
533 | ; | |
0f0d6a5a AF |
534 | |
535 | for (my $i=0;$i<$#status;$i++){ | |
536 | ||
537 | if (@status[$i]=~"^Station ") { $count++; } | |
538 | if ($count % 2){ | |
3827d1f6 AM |
539 | $col="bgcolor='$color{'color20'}'"; |
540 | }else{ | |
541 | $col="bgcolor='$color{'color22'}'"; | |
542 | } | |
0f0d6a5a AF |
543 | print"<tr><td colspan='3' $col><pre>@status[$i]</pre></td></tr>"; |
544 | if (! @status[$i]=~"^/t" ) { $count++; } | |
3827d1f6 | 545 | } |
0f0d6a5a AF |
546 | $count++; |
547 | ||
548 | foreach my $nr (@channellist_cmd){ | |
549 | if ($count % 2){ | |
3827d1f6 AM |
550 | $col="bgcolor='$color{'color20'}'"; |
551 | }else{ | |
552 | $col="bgcolor='$color{'color22'}'"; | |
553 | } | |
0f0d6a5a | 554 | print"<tr><td colspan='3' $col>$nr</td></tr>"; |
3827d1f6 AM |
555 | $count++; |
556 | } | |
0f0d6a5a AF |
557 | |
558 | for (my $i=0;$i<$#txpower_cmd;$i=$i+2){ | |
3827d1f6 AM |
559 | if ($count % 2){ |
560 | $col="bgcolor='$color{'color20'}'"; | |
561 | }else{ | |
562 | $col="bgcolor='$color{'color22'}'"; | |
563 | } | |
0f0d6a5a | 564 | print "<tr><td $col>@txpower_cmd[$i]</td></tr>"; |
3827d1f6 AM |
565 | $count++; |
566 | } | |
567 | print "</table><br>"; | |
568 | print <<END | |
182a817a | 569 | <br /> |
3827d1f6 AM |
570 | <table width='80%' cellspacing='0' class='tbl' border='0'> |
571 | <tr><td bgcolor='$color{'color20'}' align='left'><strong>$Lang::tr{'wlan clients'}</strong></td></tr> | |
182a817a JPT |
572 | <tr><td> <a href="/cgi-bin/wireless.cgi">$Lang::tr{'wlanap link wireless'}</a></td></tr> |
573 | <tr><td> <a href="/cgi-bin/dhcp.cgi">$Lang::tr{'wlanap link dhcp'}</a></td></tr> | |
3827d1f6 | 574 | <tr><td><br></td></tr> |
182a817a | 575 | </table> |
54359730 CS |
576 | END |
577 | ; | |
578 | &Header::closebox(); | |
27731caa CS |
579 | print "</form>"; |
580 | &Header::closebigbox(); | |
581 | &Header::closepage(); | |
582 | ||
27731caa CS |
583 | sub WriteConfig_hostapd{ |
584 | $wlanapsettings{'DRIVER_HOSTAPD'} = lc($wlanapsettings{'DRIVER'}); | |
585 | ||
586 | open (CONFIGFILE, ">/var/ipfire/wlanap/hostapd.conf"); | |
587 | print CONFIGFILE <<END | |
cdbeabe2 | 588 | driver=$wlanapsettings{'DRIVER_HOSTAPD'} |
54359730 | 589 | ######################### basic hostapd configuration ########################## |
891b6138 | 590 | # |
92f2665d | 591 | interface=$wlanapsettings{'INTERFACE'} |
cdbeabe2 AF |
592 | country_code=$wlanapsettings{'COUNTRY'} |
593 | ieee80211d=1 | |
f89678de | 594 | ieee80211h=1 |
7d30ef24 | 595 | channel=$wlanapsettings{'CHANNEL'} |
b8012afd CS |
596 | END |
597 | ; | |
e62efbb7 AF |
598 | if ( $wlanapsettings{'HW_MODE'} eq 'an' ){ |
599 | print CONFIGFILE <<END | |
600 | hw_mode=a | |
601 | ieee80211n=1 | |
602 | wmm_enabled=1 | |
603 | ht_capab=$wlanapsettings{'HTCAPS'} | |
604 | END | |
605 | ; | |
606 | ||
607 | }elsif ( $wlanapsettings{'HW_MODE'} eq 'gn' ){ | |
b8012afd CS |
608 | print CONFIGFILE <<END |
609 | hw_mode=g | |
610 | ieee80211n=1 | |
6e346fe0 CS |
611 | wmm_enabled=1 |
612 | ht_capab=$wlanapsettings{'HTCAPS'} | |
b8012afd | 613 | END |
f887bf5f MT |
614 | ; |
615 | ||
616 | }elsif ( $wlanapsettings{'HW_MODE'} eq 'ac' ){ | |
617 | print CONFIGFILE <<END | |
618 | hw_mode=a | |
619 | ieee80211ac=1 | |
620 | ieee80211n=1 | |
621 | wmm_enabled=1 | |
622 | ht_capab=$wlanapsettings{'HTCAPS'} | |
623 | vht_capab=$wlanapsettings{'VHTCAPS'} | |
dc850cb3 | 624 | vht_oper_chwidth=1 |
f887bf5f | 625 | END |
b8012afd CS |
626 | ; |
627 | ||
628 | }else{ | |
629 | print CONFIGFILE <<END | |
8ad457eb CS |
630 | hw_mode=$wlanapsettings{'HW_MODE'} |
631 | END | |
b8012afd CS |
632 | ; |
633 | ||
634 | } | |
635 | ||
8ad457eb | 636 | print CONFIGFILE <<END |
27731caa CS |
637 | logger_syslog=-1 |
638 | logger_syslog_level=$wlanapsettings{'SYSLOGLEVEL'} | |
639 | logger_stdout=-1 | |
54359730 | 640 | logger_stdout_level=$wlanapsettings{'DEBUG'} |
7d30ef24 | 641 | auth_algs=1 |
27731caa CS |
642 | ctrl_interface=/var/run/hostapd |
643 | ctrl_interface_group=0 | |
70a7c454 | 644 | disassoc_low_ack=1 |
27731caa CS |
645 | END |
646 | ; | |
54359730 CS |
647 | if ( $wlanapsettings{'HIDESSID'} eq 'on' ){ |
648 | print CONFIGFILE <<END | |
649 | ssid=$wlanapsettings{'SSID'} | |
650 | ignore_broadcast_ssid=2 | |
651 | END | |
652 | ; | |
653 | ||
654 | }else{ | |
655 | print CONFIGFILE <<END | |
656 | ssid=$wlanapsettings{'SSID'} | |
657 | ignore_broadcast_ssid=0 | |
658 | END | |
659 | ; | |
660 | ||
661 | } | |
92f2665d | 662 | |
5b4464a9 PM |
663 | # https://forum.ipfire.org/viewtopic.php?f=22&t=12274&p=79070#p79070 |
664 | if ( $wlanapsettings{'CLIENTISOLATION'} eq 'on' ){ | |
665 | print CONFIGFILE <<END | |
666 | ap_isolate=1 | |
667 | END | |
668 | ; | |
669 | } | |
670 | ||
d823d5f0 AF |
671 | if ( $wlanapsettings{'NOSCAN'} eq 'on' ){ |
672 | print CONFIGFILE <<END | |
673 | noscan=1 | |
674 | END | |
675 | ; | |
676 | ||
677 | }else{ | |
678 | print CONFIGFILE <<END | |
679 | noscan=0 | |
680 | END | |
681 | ; | |
682 | ||
683 | } | |
684 | ||
37a83c83 MT |
685 | # Management Frame Protection (802.11w) |
686 | if ($wlanapsettings{'IEEE80211W'} eq "on") { | |
687 | print CONFIGFILE "ieee80211w=2\n"; | |
13cbb92a MT |
688 | } elsif ($wlanapsettings{'IEEE80211W'} eq "optional") { |
689 | print CONFIGFILE "ieee80211w=1\n"; | |
37a83c83 MT |
690 | } else { |
691 | print CONFIGFILE "ieee80211w=0\n"; | |
692 | } | |
693 | ||
8c2f203c CS |
694 | if ( $wlanapsettings{'ENC'} eq 'wpa1'){ |
695 | print CONFIGFILE <<END | |
696 | ######################### wpa hostapd configuration ############################ | |
891b6138 | 697 | # |
8c2f203c CS |
698 | wpa=1 |
699 | wpa_passphrase=$wlanapsettings{'PWD'} | |
891b6138 | 700 | wpa_key_mgmt=WPA-PSK |
e62efbb7 | 701 | wpa_pairwise=TKIP |
8c2f203c CS |
702 | END |
703 | ; | |
704 | }elsif ( $wlanapsettings{'ENC'} eq 'wpa2'){ | |
54359730 CS |
705 | print CONFIGFILE <<END |
706 | ######################### wpa hostapd configuration ############################ | |
891b6138 | 707 | # |
8c2f203c | 708 | wpa=2 |
54359730 | 709 | wpa_passphrase=$wlanapsettings{'PWD'} |
891b6138 | 710 | wpa_key_mgmt=WPA-PSK |
e62efbb7 AF |
711 | rsn_pairwise=CCMP |
712 | END | |
f832c758 MT |
713 | ; |
714 | }elsif ( $wlanapsettings{'ENC'} eq 'wpa3'){ | |
715 | print CONFIGFILE <<END | |
716 | ######################### wpa hostapd configuration ############################ | |
717 | # | |
718 | wpa=2 | |
719 | wpa_passphrase=$wlanapsettings{'PWD'} | |
720 | wpa_key_mgmt=SAE | |
721 | rsn_pairwise=CCMP | |
722 | END | |
e62efbb7 AF |
723 | ; |
724 | } elsif ( $wlanapsettings{'ENC'} eq 'wpa1+2'){ | |
725 | print CONFIGFILE <<END | |
726 | ######################### wpa hostapd configuration ############################ | |
727 | # | |
728 | wpa=3 | |
729 | wpa_passphrase=$wlanapsettings{'PWD'} | |
730 | wpa_key_mgmt=WPA-PSK | |
731 | wpa_pairwise=TKIP | |
732 | rsn_pairwise=CCMP | |
54359730 | 733 | END |
f832c758 MT |
734 | ; |
735 | }elsif ( $wlanapsettings{'ENC'} eq 'wpa2+3'){ | |
736 | print CONFIGFILE <<END | |
737 | ######################### wpa hostapd configuration ############################ | |
738 | # | |
739 | wpa=2 | |
740 | wpa_passphrase=$wlanapsettings{'PWD'} | |
741 | wpa_key_mgmt=WPA-PSK SAE | |
742 | rsn_pairwise=CCMP | |
743 | END | |
54359730 CS |
744 | ; |
745 | } | |
27731caa | 746 | close CONFIGFILE; |
92f2665d | 747 | |
8aa49c15 | 748 | open (MACFILE, ">/var/ipfire/wlanap/macfile"); |
23e368ab CS |
749 | foreach(@macs){ |
750 | $_ =~ s/\r//gi; | |
751 | chomp($_); | |
752 | if ( $_ ne "" ){print MACFILE $_;} | |
753 | } | |
92f2665d | 754 | close MACFILE; |
27731caa | 755 | } |