]>
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); | |
57 | &General::readhash("/srv/web/ipfire/html/themes/".$mainsettings{'THEME'}."/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'; |
27731caa | 79 | |
27731caa | 80 | &General::readhash("/var/ipfire/wlanap/settings", \%wlanapsettings); |
23e368ab | 81 | &Header::getcgihash(\%wlanapsettings); |
27731caa | 82 | |
23e368ab | 83 | my @macs = $wlanapsettings{'MACS'}; |
27731caa | 84 | |
23e368ab CS |
85 | delete $wlanapsettings{'__CGI__'}; |
86 | delete $wlanapsettings{'x'}; | |
87 | delete $wlanapsettings{'y'}; | |
88 | delete $wlanapsettings{'MACS'}; | |
89 | delete $wlanapsettings{'ACCEPT_MACS'}; | |
90 | delete $wlanapsettings{'DENY_MACS'}; | |
27731caa CS |
91 | |
92 | &Header::showhttpheaders(); | |
93 | ||
182a817a JPT |
94 | my $string=(); |
95 | my $status=(); | |
96 | my $errormessage = ''; | |
97 | my $memory = 0; | |
98 | my @memory=(); | |
99 | my @pid=(); | |
100 | my @hostapd=(); | |
101 | sub pid | |
102 | { | |
103 | # for pid and memory | |
104 | open(FILE, '/usr/local/bin/addonctrl hostapd status | '); | |
105 | @hostapd = <FILE>; | |
106 | close(FILE); | |
107 | $string = join("", @hostapd); | |
108 | $string =~ s/[a-z_]//gi; | |
109 | $string =~ s/\[[0-1]\;[0-9]+//gi; | |
110 | $string =~ s/[\(\)\.]//gi; | |
111 | $string =~ s/ //gi; | |
112 | $string =~ s/\e//gi; | |
113 | @pid = split(/\s/,$string); | |
114 | if (open(FILE, "/proc/$pid[0]/statm")){ | |
115 | my $temp = <FILE>; | |
116 | @memory = split(/ /,$temp); | |
117 | close(FILE); | |
118 | } | |
119 | $memory+=$memory[0]; | |
120 | } | |
121 | pid(); | |
122 | ||
123 | ||
124 | ||
125 | if ( $wlanapsettings{'ACTION'} eq "$Lang::tr{'wlanap del interface'}" ){ | |
126 | delete $wlanapsettings{'INTERFACE'}; | |
127 | &General::writehash("/var/ipfire/wlanap/settings", \%wlanapsettings); | |
128 | } | |
129 | ||
23e368ab | 130 | if ( $wlanapsettings{'ACTION'} eq "$Lang::tr{'save'}" ){ |
3af89eb5 | 131 | # verify WPA Passphrase - only with enabled enc |
e62efbb7 | 132 | if (($wlanapsettings{'ENC'} eq "wpa1") || ($wlanapsettings{'ENC'} eq "wpa2") || ($wlanapsettings{'ENC'} eq "wpa1+2")){ |
3af89eb5 | 133 | # must be 8 .. 63 characters |
182a817a JPT |
134 | if ( (length($wlanapsettings{'PWD'}) < 8) || (length($wlanapsettings{'PWD'}) > 63)){ |
135 | $errormessage .= "$Lang::tr{'wlanap invalid wpa'}<br />"; | |
136 | } | |
3af89eb5 | 137 | # only ASCII alowed |
cdbeabe2 | 138 | if ( !($wlanapsettings{'PWD'} !~ /[^\x00-\x7f]/) ){ |
3af89eb5 AF |
139 | $errormessage .= "$Lang::tr{'wlanap invalid wpa'}<br />"; |
140 | } | |
27731caa CS |
141 | } |
142 | ||
143 | if ( $errormessage eq '' ){ | |
92f2665d | 144 | &General::writehash("/var/ipfire/wlanap/settings", \%wlanapsettings); |
27731caa CS |
145 | &WriteConfig_hostapd(); |
146 | ||
91197a3f | 147 | system("/usr/local/bin/wlanapctrl restart >/dev/null 2>&1"); |
182a817a | 148 | pid(); |
27731caa | 149 | } |
182a817a | 150 | }elsif ( $wlanapsettings{'ACTION'} eq "$Lang::tr{'wlanap interface'}" ){ |
92f2665d | 151 | &General::writehash("/var/ipfire/wlanap/settings", \%wlanapsettings); |
182a817a | 152 | }elsif ( ($wlanapsettings{'ACTION'} eq "$Lang::tr{'start'}") && ($memory == 0) ){ |
27731caa | 153 | system("/usr/local/bin/wlanapctrl start >/dev/null 2>&1"); |
182a817a JPT |
154 | pid(); |
155 | }elsif ( $wlanapsettings{'ACTION'} eq "$Lang::tr{'stop'}" ){ | |
27731caa | 156 | system("/usr/local/bin/wlanapctrl stop >/dev/null 2>&1"); |
182a817a | 157 | $memory=0; |
27731caa CS |
158 | } |
159 | ||
d3790c6a | 160 | &Header::openpage($Lang::tr{'wlanap configuration'}, 1, '', ''); |
27731caa | 161 | &Header::openbigbox('100%', 'left', '', $errormessage); |
27731caa CS |
162 | |
163 | if ( $errormessage ){ | |
54359730 | 164 | &Header::openbox('100%', 'center', $Lang::tr{'error messages'}); |
27731caa CS |
165 | print "<class name='base'>$errormessage\n"; |
166 | print " </class>\n"; | |
167 | &Header::closebox(); | |
168 | } | |
169 | ||
170 | ||
171 | # Found this usefull piece of code in BlockOutTraffic AddOn 8-) | |
172 | # fwrules.cgi | |
173 | ############### | |
174 | # DEBUG DEBUG | |
175 | if ( $debug ){ | |
54359730 | 176 | &Header::openbox('100%', 'center', 'DEBUG'); |
27731caa | 177 | my $debugCount = 0; |
23e368ab CS |
178 | foreach my $line (sort keys %wlanapsettings) { |
179 | print "$line = '$wlanapsettings{$line}'<br />\n"; | |
27731caa CS |
180 | $debugCount++; |
181 | } | |
182 | print " Count: $debugCount\n"; | |
183 | &Header::closebox(); | |
184 | } | |
185 | # DEBUG DEBUG | |
186 | ############### | |
187 | ||
188 | # | |
189 | # Driver and status detection | |
190 | # | |
191 | my $wlan_card_status = 'dummy'; | |
192 | my $wlan_ap_status = ''; | |
92f2665d CS |
193 | my $message = ""; |
194 | ||
195 | $selected{'INTERFACE'}{'green0'} = ''; | |
196 | $selected{'INTERFACE'}{'blue0'} = ''; | |
197 | $selected{'ENC'}{$wlanapsettings{'INTERFACE'}} = "selected='selected'"; | |
27731caa | 198 | |
92f2665d | 199 | if ( ($wlanapsettings{'INTERFACE'} eq '') ){ |
182a817a | 200 | $message = $Lang::tr{'wlanap select interface'}; |
92f2665d CS |
201 | &Header::openbox('100%', 'center', "WLAN AP"); |
202 | print <<END | |
203 | $message<br /> | |
204 | <form method='post' action='$ENV{'SCRIPT_NAME'}'> | |
205 | <select name='INTERFACE'> | |
92f2665d CS |
206 | END |
207 | ; | |
208 | if ( $netsettings{'BLUE_DEV'} ne ''){ | |
209 | print "<option value='blue0' $selected{'INTERFACE'}{'blue0'}>blue0</option>"; | |
210 | } | |
211 | print <<END | |
182a817a | 212 | <option value='green0' $selected{'INTERFACE'}{'green0'}>green0</option> |
92f2665d | 213 | </select> |
182a817a JPT |
214 | <br /><br /> |
215 | <hr size='1'> | |
216 | <input type='submit' name='ACTION' value='$Lang::tr{'wlanap interface'}' /></form> | |
92f2665d CS |
217 | END |
218 | ; | |
219 | &Header::closebox(); | |
220 | &Header::closebigbox(); | |
221 | &Header::closepage(); | |
222 | exit; | |
27731caa | 223 | }else{ |
92f2665d | 224 | my $cmd_out = `/usr/sbin/iwconfig $wlanapsettings{'INTERFACE'} 2>/dev/null`; |
27731caa CS |
225 | |
226 | if ( $cmd_out eq '' ){ | |
182a817a | 227 | $message = "$Lang::tr{'wlanap no interface'}"; |
92f2665d | 228 | $wlan_card_status = ''; |
27731caa | 229 | }else{ |
92f2665d | 230 | $cmd_out = `/sbin/ifconfig | /bin/grep $wlanapsettings{'INTERFACE'}`; |
27731caa CS |
231 | if ( $cmd_out eq '' ){ |
232 | $wlan_card_status = 'down'; | |
233 | }else{ | |
234 | $wlan_card_status = 'up'; | |
92f2665d | 235 | $cmd_out = `/usr/sbin/iwconfig $wlanapsettings{'INTERFACE'} | /bin/grep "Mode:Master"`; |
27731caa CS |
236 | if ( $cmd_out ne '' ){ |
237 | $wlan_ap_status = 'up'; | |
27731caa CS |
238 | } |
239 | } | |
240 | } | |
241 | } | |
242 | ||
e62efbb7 AF |
243 | # Change old "n" to "gn" |
244 | if ( $wlanapsettings{'HW_MODE'} eq 'n' ) { | |
245 | $wlanapsettings{'HW_MODE'}='gn'; | |
246 | } | |
247 | ||
b8990355 CS |
248 | $checked{'HIDESSID'}{'off'} = ''; |
249 | $checked{'HIDESSID'}{'on'} = ''; | |
250 | $checked{'HIDESSID'}{$wlanapsettings{'HIDESSID'}} = "checked='checked'"; | |
27731caa | 251 | |
d823d5f0 AF |
252 | $checked{'NOSCAN'}{'off'} = ''; |
253 | $checked{'NOSCAN'}{'on'} = ''; | |
254 | $checked{'NOSCAN'}{$wlanapsettings{'NOSCAN'}} = "checked='checked'"; | |
255 | ||
5b4464a9 PM |
256 | $checked{'CLIENTISOLATION'}{'off'} = ''; |
257 | $checked{'CLIENTISOLATION'}{'on'} = ''; | |
258 | $checked{'CLIENTISOLATION'}{$wlanapsettings{'CLIENTISOLATION'}} = "checked='checked'"; | |
259 | ||
27731caa | 260 | $selected{'ENC'}{$wlanapsettings{'ENC'}} = "selected='selected'"; |
30313f28 | 261 | $selected{'CHANNEL'}{$wlanapsettings{'CHANNEL'}} = "selected='selected'"; |
c3d9a16d | 262 | $selected{'COUNTRY'}{$wlanapsettings{'COUNTRY'}} = "selected='selected'"; |
54359730 | 263 | $selected{'TXPOWER'}{$wlanapsettings{'TXPOWER'}} = "selected='selected'"; |
7d30ef24 | 264 | $selected{'HW_MODE'}{$wlanapsettings{'HW_MODE'}} = "selected='selected'"; |
92f2665d | 265 | $selected{'MACMODE'}{$wlanapsettings{'MACMODE'}} = "selected='selected'"; |
27731caa | 266 | |
c3d9a16d | 267 | my $monwlaninterface = $wlanapsettings{'INTERFACE'}; |
56c2cc65 | 268 | if ( -d '/sys/class/net/mon.'.$wlanapsettings{'INTERFACE'} ) { |
c3d9a16d AF |
269 | $monwlaninterface = 'mon.'.$wlanapsettings{'INTERFACE'}; |
270 | } | |
271 | ||
0f0d6a5a AF |
272 | my @channellist_cmd; |
273 | my @channellist; | |
274 | ||
275 | if ( $wlanapsettings{'DRIVER'} eq 'NL80211' ){ | |
276 | my $wiphy = `iw dev $wlanapsettings{'INTERFACE'} info | grep wiphy | cut -d" " -f2`; | |
277 | chomp $wiphy; | |
278 | ||
05583186 | 279 | @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 |
280 | # get available channels |
281 | ||
282 | my @temp; | |
283 | foreach (@channellist_cmd){ | |
284 | $_ =~ /(.*) \[(\d+)(.*)\]/; | |
285 | $channel = $2;chomp $channel; | |
12f74b8f | 286 | if ( $channel =~ /\d+/ ){push(@temp,$channel + 0);} |
0f0d6a5a AF |
287 | } |
288 | @channellist = @temp; | |
289 | } else { | |
290 | @channellist_cmd = `iwlist $monwlaninterface channel|tail -n +2 2>/dev/null`; | |
27731caa | 291 | # get available channels |
27731caa | 292 | |
54359730 | 293 | my @temp; |
8c2f203c | 294 | foreach (@channellist_cmd){ |
54359730 | 295 | $_ =~ /(.*)Channel (\d+)(.*):/; |
8c2f203c | 296 | $channel = $2;chomp $channel; |
12f74b8f | 297 | if ( $channel =~ /\d+/ ){push(@temp,$channel + 0);} |
27731caa | 298 | } |
0f0d6a5a AF |
299 | @channellist = @temp; |
300 | } | |
54359730 | 301 | |
c3d9a16d AF |
302 | my @countrylist_cmd = `regdbdump /usr/lib/crda/regulatory.bin 2>/dev/null`; |
303 | # get available country codes | |
304 | ||
8e23b351 | 305 | my @temp = "00"; |
c3d9a16d AF |
306 | foreach (@countrylist_cmd){ |
307 | $_ =~ /country (.*):/; | |
308 | $country = $1;chomp $country; | |
309 | if ( $country =~ /[0,A-Z][0,A-Z]/ ) {push(@temp,$country);} | |
310 | } | |
311 | my @countrylist = @temp; | |
312 | ||
313 | my @txpower_cmd = `iwlist $monwlaninterface txpower 2>/dev/null`; | |
314 | if ( $wlanapsettings{'DRIVER'} eq 'NL80211' ){ | |
315 | # There is a bug with NL80211 only all devices can displayed | |
316 | @txpower_cmd = `iwlist txpower 2>/dev/null | sed -e "s|unknown transmit-power information.||g"`; | |
317 | } | |
318 | # get available power | |
27731caa | 319 | |
27731caa | 320 | $selected{'SYSLOGLEVEL'}{$wlanapsettings{'SYSLOGLEVEL'}} = "selected='selected'"; |
27731caa CS |
321 | $selected{'DEBUG'}{$wlanapsettings{'DEBUG'}} = "selected='selected'"; |
322 | ||
323 | # | |
324 | # Status box | |
325 | # | |
54359730 | 326 | &Header::openbox('100%', 'center', "WLAN AP"); |
27731caa | 327 | print <<END |
3827d1f6 | 328 | <table width='80%' cellspacing='1' class='tbl'> |
27731caa CS |
329 | END |
330 | ; | |
182a817a | 331 | |
27731caa | 332 | if ( $wlan_card_status ne '' ){ |
3827d1f6 AM |
333 | 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>"; |
334 | print "<tr><td class='base'>$Lang::tr{'wlanap wlan card'} ($wlanapsettings{'DRIVER'})</td>"; | |
27731caa | 335 | print $wlan_card_status eq 'up' ? $status_started : $status_stopped; |
3827d1f6 | 336 | print"<td colspan='4'></td></tr>"; |
d3790c6a | 337 | print "<tr><td class='base' bgcolor='$color{'color22'}'>$Lang::tr{'wlanap'}</td>"; |
27731caa | 338 | print $wlan_ap_status eq 'up' ? $status_started : $status_stopped; |
3827d1f6 AM |
339 | if ( ($memory != 0) && (@pid[0] ne "///") ){ |
340 | print "<td bgcolor='$color{'color22'}' align='center'>@pid[0]</td>"; | |
341 | print "<td bgcolor='$color{'color22'}' align='center'>$memory KB</td>"; | |
342 | 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>"; | |
343 | 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>"; | |
344 | }else{ | |
345 | print"<td colspan='2' bgcolor='$color{'color22'}'></td>"; | |
346 | 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>"; | |
347 | 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>"; | |
348 | } | |
182a817a | 349 | |
27731caa | 350 | }else{ |
3827d1f6 | 351 | print "<tr><td class='base'>$message"; |
182a817a JPT |
352 | } |
353 | print "</table>"; | |
354 | ||
3827d1f6 AM |
355 | if ( $wlan_card_status eq '' ){ |
356 | print "<br />"; | |
357 | print "<table width='80%' cellspacing='0' border='0'>"; | |
358 | print "<tr align='center'>"; | |
359 | print "<td colspan='4'></td>"; | |
182a817a | 360 | print "</tr>"; |
3827d1f6 AM |
361 | print "<tr align='center'>"; |
362 | print "<td width='40%'> </td>"; | |
363 | 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>"; | |
364 | print "<td width='20%'></td>"; | |
365 | print "<td width='20%'></td>"; | |
182a817a JPT |
366 | print "</tr>"; |
367 | print "</table>"; | |
27731caa | 368 | } |
27731caa CS |
369 | |
370 | if ( $wlan_card_status eq '' ){ | |
92f2665d | 371 | &Header::closebox(); |
27731caa CS |
372 | &Header::closebigbox(); |
373 | &Header::closepage(); | |
374 | exit 0; | |
375 | } | |
27731caa | 376 | print <<END |
3827d1f6 | 377 | <br><br> |
23e368ab | 378 | <form method='post' action='$ENV{'SCRIPT_NAME'}'> |
3827d1f6 AM |
379 | <table width='80%' cellspacing='0' class='tbl' border='0'> |
380 | <tr><th bgcolor='$color{'color20'}' colspan='4' align='left'><strong>$Lang::tr{'wlanap wlan settings'}</strong></th></tr> | |
381 | <tr><td colspan='4'><br></td></tr> | |
382 | <tr><td width='25%' class='base'>SSID: </td><td class='base' colspan='3'><input type='text' name='SSID' size='30' value='$wlanapsettings{'SSID'}' /></td></tr> | |
0d4e628e JPT |
383 | <!--SSID Broadcast: on => HIDESSID: off --> |
384 | <tr><td width='25%' class='base'>SSID Broadcast: </td><td class='base' colspan='3'>on <input type='radio' name='HIDESSID' value='off' $checked{'HIDESSID'}{'off'} /> | <input type='radio' name='HIDESSID' value='on' $checked{'HIDESSID'}{'on'} /> off</td></tr> | |
5b4464a9 | 385 | <tr><td width='25%' class='base'>Client Isolation: </td><td class='base' colspan='3'>on <input type='radio' name='CLIENTISOLATION' value='off' $checked{'CLIENTISOLATION'}{'off'} /> | <input type='radio' name='CLIENTISOLATION' value='on' $checked{'CLIENTISOLATION'}{'on'} /> off</td></tr> |
3827d1f6 AM |
386 | |
387 | ||
388 | <tr><td width='25%' class='base'>$Lang::tr{'wlanap country'}: </td><td class='base' colspan='3'> | |
389 | <select name='COUNTRY'> | |
390 | END | |
391 | ; | |
392 | foreach $country (@countrylist){ | |
393 | print "<option $selected{'COUNTRY'}{$country}>$country</option>"; | |
394 | } | |
395 | print<<END | |
396 | </select></td></tr> | |
7d30ef24 AF |
397 | <tr><td width='25%' class='base'>HW Mode: </td><td class='base' colspan='3'> |
398 | <select name='HW_MODE'> | |
182a817a JPT |
399 | <option value='a' $selected{'HW_MODE'}{'a'}>802.11a</option> |
400 | <option value='b' $selected{'HW_MODE'}{'b'}>802.11b</option> | |
401 | <option value='g' $selected{'HW_MODE'}{'g'}>802.11g</option> | |
e62efbb7 AF |
402 | <option value='an' $selected{'HW_MODE'}{'an'}>802.11an</option> |
403 | <option value='gn' $selected{'HW_MODE'}{'gn'}>802.11gn</option> | |
f887bf5f | 404 | <option value='ac' $selected{'HW_MODE'}{'ac'}>802.11ac</option> |
7d30ef24 AF |
405 | </select> |
406 | </td></tr> | |
fe3f3050 AF |
407 | END |
408 | ; | |
409 | ||
fe3f3050 AF |
410 | if ( scalar @channellist > 0 ){ |
411 | print <<END | |
182a817a | 412 | <tr><td width='25%' class='base'>$Lang::tr{'wlanap channel'}: </td><td class='base' colspan='3'> |
30313f28 | 413 | <select name='CHANNEL'> |
27731caa CS |
414 | END |
415 | ; | |
fe3f3050 AF |
416 | foreach $channel (@channellist){ |
417 | print "<option $selected{'CHANNEL'}{$channel}>$channel</option>"; | |
418 | } | |
419 | print "</select></td></tr>" | |
420 | } else { | |
421 | print <<END | |
422 | <tr><td width='25%' class='base'>$Lang::tr{'wlanap channel'}: </td><td class='base' colspan='3'> | |
423 | <input type='text' name='CHANNEL' size='10' value='$wlanapsettings{'CHANNEL'}' /> | |
424 | </td></tr> | |
425 | END | |
426 | ; | |
27731caa | 427 | } |
3827d1f6 | 428 | print<<END |
d823d5f0 | 429 | <tr><td width='25%' class='base'>$Lang::tr{'wlanap neighbor scan'}: </td><td class='base' >on <input type='radio' name='NOSCAN' value='off' $checked{'NOSCAN'}{'off'} /> | <input type='radio' name='NOSCAN' value='on' $checked{'NOSCAN'}{'on'} /> off</td><td class='base' colspan='2'>$Lang::tr{'wlanap neighbor scan warning'}</td></tr> |
3827d1f6 AM |
430 | <tr><td colspan='4'><br></td></tr> |
431 | <tr><td width='25%' class='base'>$Lang::tr{'wlanap encryption'}: </td><td class='base' colspan='3'> | |
432 | <select name='ENC'> | |
433 | <option value='none' $selected{'ENC'}{'none'}>$Lang::tr{'wlanap none'}</option> | |
434 | <option value='wpa1' $selected{'ENC'}{'wpa1'}>WPA1</option> | |
435 | <option value='wpa2' $selected{'ENC'}{'wpa2'}>WPA2</option> | |
436 | <option value='wpa1+2' $selected{'ENC'}{'wpa1+2'}>WPA1+2</option> | |
437 | </select> | |
438 | </td></tr> | |
439 | <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> | |
440 | <tr><td colspan='4'><br></td></tr> | |
c3d9a16d AF |
441 | END |
442 | ; | |
27731caa | 443 | print <<END |
3827d1f6 | 444 | <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 | 445 | <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 | 446 | <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 |
447 | <tr><td width='25%' class='base'>Loglevel (hostapd): </td><td class='base' width='25%'> |
448 | <select name='SYSLOGLEVEL'> | |
182a817a JPT |
449 | <option value='0' $selected{'SYSLOGLEVEL'}{'0'}>0 ($Lang::tr{'wlanap verbose'})</option> |
450 | <option value='1' $selected{'SYSLOGLEVEL'}{'1'}>1 ($Lang::tr{'wlanap debugging'})</option> | |
451 | <option value='2' $selected{'SYSLOGLEVEL'}{'2'}>2 ($Lang::tr{'wlanap informations'})</option> | |
452 | <option value='3' $selected{'SYSLOGLEVEL'}{'3'}>3 ($Lang::tr{'wlanap notifications'})</option> | |
453 | <option value='4' $selected{'SYSLOGLEVEL'}{'4'}>4 ($Lang::tr{'wlanap warnings'})</option> | |
27731caa CS |
454 | </select> |
455 | </td> | |
456 | <td width='25%' class='base'>Debuglevel (hostapd): </td><td class='base' width='25%'> | |
457 | <select name='DEBUG'> | |
182a817a JPT |
458 | <option value='0' $selected{'DEBUG'}{'0'}>0 ($Lang::tr{'wlanap verbose'})</option> |
459 | <option value='1' $selected{'DEBUG'}{'1'}>1 ($Lang::tr{'wlanap debugging'})</option> | |
460 | <option value='2' $selected{'DEBUG'}{'2'}>2 ($Lang::tr{'wlanap informations'})</option> | |
461 | <option value='3' $selected{'DEBUG'}{'3'}>3 ($Lang::tr{'wlanap notifications'})</option> | |
462 | <option value='4' $selected{'DEBUG'}{'4'}>4 ($Lang::tr{'wlanap warnings'})</option> | |
27731caa CS |
463 | </select> |
464 | </td></tr> | |
3827d1f6 | 465 | <tr><td colspan='4'><br></td></tr> |
27731caa | 466 | </table> |
92f2665d CS |
467 | END |
468 | ; | |
469 | if ( $wlanapsettings{'INTERFACE'} =~ /green0/ ){ | |
470 | print <<END | |
471 | <br /> | |
3827d1f6 AM |
472 | <table width='80%' cellspacing='0' class='tbl' border='1'> |
473 | <tr> | |
474 | <th colspan='3' align='left'>$Lang::tr{'mac filter'}</th> | |
475 | </tr> | |
92f2665d CS |
476 | <td width='25%' class='base'>Mac Filter: </td><td class='base' width='25%'> |
477 | <select name='MACMODE'> | |
478 | <option value='0' $selected{'MACMODE'}{'0'}>0 (off)</option> | |
8aa49c15 CS |
479 | <option value='1' $selected{'MACMODE'}{'1'}>1 (Accept MACs)</option> |
480 | <option value='2' $selected{'MACMODE'}{'2'}>2 (Deny MACs)</option> | |
92f2665d | 481 | </select> |
8aa49c15 | 482 | </td><td colspan='2'>Mac Adress List (one per line)<br /><textarea name='MACS' cols='20' rows='5' wrap='off'> |
92f2665d CS |
483 | END |
484 | ; | |
8aa49c15 | 485 | print `cat /var/ipfire/wlanap/macfile`; |
92f2665d CS |
486 | print <<END |
487 | </textarea></td> | |
92f2665d CS |
488 | </table> |
489 | END | |
490 | ; | |
491 | } | |
492 | print <<END | |
54359730 | 493 | <br /> |
3827d1f6 | 494 | <table width='80%' cellspacing='0'> |
735fce60 | 495 | <tr><td align='center'> |
182a817a | 496 | <form method='post' action='$ENV{'SCRIPT_NAME'}'> |
735fce60 JPT |
497 | <input type='hidden' name='ACTION' value=$Lang::tr{'save'} /> |
498 | <input type='image' alt='$Lang::tr{'save'}' title='$Lang::tr{'save'}' src='/images/media-floppy.png' /></form></td> | |
27731caa CS |
499 | </tr> |
500 | </table> | |
501 | END | |
502 | ; | |
0f0d6a5a | 503 | my @status; |
7d30ef24 | 504 | if ( $wlanapsettings{'DRIVER'} eq 'NL80211' ){ |
513c321e | 505 | @status = `iw dev $wlanapsettings{'INTERFACE'} info && iw dev $wlanapsettings{'INTERFACE'} station dump && echo ""`; |
7d30ef24 | 506 | } |
54359730 CS |
507 | print <<END |
508 | <br /> | |
3827d1f6 AM |
509 | <table width='80%' cellspacing='0' class='tbl'> |
510 | <tr><th colspan='3' bgcolor='$color{'color20'}' align='left'><strong>$Lang::tr{'wlanap wlan status'}</strong></th></tr> | |
511 | END | |
512 | ; | |
0f0d6a5a AF |
513 | |
514 | for (my $i=0;$i<$#status;$i++){ | |
515 | ||
516 | if (@status[$i]=~"^Station ") { $count++; } | |
517 | if ($count % 2){ | |
3827d1f6 AM |
518 | $col="bgcolor='$color{'color20'}'"; |
519 | }else{ | |
520 | $col="bgcolor='$color{'color22'}'"; | |
521 | } | |
0f0d6a5a AF |
522 | print"<tr><td colspan='3' $col><pre>@status[$i]</pre></td></tr>"; |
523 | if (! @status[$i]=~"^/t" ) { $count++; } | |
3827d1f6 | 524 | } |
0f0d6a5a AF |
525 | $count++; |
526 | ||
527 | foreach my $nr (@channellist_cmd){ | |
528 | if ($count % 2){ | |
3827d1f6 AM |
529 | $col="bgcolor='$color{'color20'}'"; |
530 | }else{ | |
531 | $col="bgcolor='$color{'color22'}'"; | |
532 | } | |
0f0d6a5a | 533 | print"<tr><td colspan='3' $col>$nr</td></tr>"; |
3827d1f6 AM |
534 | $count++; |
535 | } | |
0f0d6a5a AF |
536 | |
537 | for (my $i=0;$i<$#txpower_cmd;$i=$i+2){ | |
3827d1f6 AM |
538 | if ($count % 2){ |
539 | $col="bgcolor='$color{'color20'}'"; | |
540 | }else{ | |
541 | $col="bgcolor='$color{'color22'}'"; | |
542 | } | |
0f0d6a5a | 543 | print "<tr><td $col>@txpower_cmd[$i]</td></tr>"; |
3827d1f6 AM |
544 | $count++; |
545 | } | |
546 | print "</table><br>"; | |
547 | print <<END | |
182a817a | 548 | <br /> |
3827d1f6 AM |
549 | <table width='80%' cellspacing='0' class='tbl' border='0'> |
550 | <tr><td bgcolor='$color{'color20'}' align='left'><strong>$Lang::tr{'wlan clients'}</strong></td></tr> | |
182a817a JPT |
551 | <tr><td> <a href="/cgi-bin/wireless.cgi">$Lang::tr{'wlanap link wireless'}</a></td></tr> |
552 | <tr><td> <a href="/cgi-bin/dhcp.cgi">$Lang::tr{'wlanap link dhcp'}</a></td></tr> | |
3827d1f6 | 553 | <tr><td><br></td></tr> |
182a817a | 554 | </table> |
54359730 CS |
555 | END |
556 | ; | |
557 | &Header::closebox(); | |
27731caa CS |
558 | print "</form>"; |
559 | &Header::closebigbox(); | |
560 | &Header::closepage(); | |
561 | ||
27731caa CS |
562 | sub WriteConfig_hostapd{ |
563 | $wlanapsettings{'DRIVER_HOSTAPD'} = lc($wlanapsettings{'DRIVER'}); | |
564 | ||
565 | open (CONFIGFILE, ">/var/ipfire/wlanap/hostapd.conf"); | |
566 | print CONFIGFILE <<END | |
cdbeabe2 | 567 | driver=$wlanapsettings{'DRIVER_HOSTAPD'} |
54359730 | 568 | ######################### basic hostapd configuration ########################## |
891b6138 | 569 | # |
92f2665d | 570 | interface=$wlanapsettings{'INTERFACE'} |
cdbeabe2 AF |
571 | country_code=$wlanapsettings{'COUNTRY'} |
572 | ieee80211d=1 | |
f89678de | 573 | ieee80211h=1 |
7d30ef24 | 574 | channel=$wlanapsettings{'CHANNEL'} |
b8012afd CS |
575 | END |
576 | ; | |
e62efbb7 AF |
577 | if ( $wlanapsettings{'HW_MODE'} eq 'an' ){ |
578 | print CONFIGFILE <<END | |
579 | hw_mode=a | |
580 | ieee80211n=1 | |
581 | wmm_enabled=1 | |
582 | ht_capab=$wlanapsettings{'HTCAPS'} | |
583 | END | |
584 | ; | |
585 | ||
586 | }elsif ( $wlanapsettings{'HW_MODE'} eq 'gn' ){ | |
b8012afd CS |
587 | print CONFIGFILE <<END |
588 | hw_mode=g | |
589 | ieee80211n=1 | |
6e346fe0 CS |
590 | wmm_enabled=1 |
591 | ht_capab=$wlanapsettings{'HTCAPS'} | |
b8012afd | 592 | END |
f887bf5f MT |
593 | ; |
594 | ||
595 | }elsif ( $wlanapsettings{'HW_MODE'} eq 'ac' ){ | |
596 | print CONFIGFILE <<END | |
597 | hw_mode=a | |
598 | ieee80211ac=1 | |
599 | ieee80211n=1 | |
600 | wmm_enabled=1 | |
601 | ht_capab=$wlanapsettings{'HTCAPS'} | |
602 | vht_capab=$wlanapsettings{'VHTCAPS'} | |
603 | END | |
b8012afd CS |
604 | ; |
605 | ||
606 | }else{ | |
607 | print CONFIGFILE <<END | |
8ad457eb CS |
608 | hw_mode=$wlanapsettings{'HW_MODE'} |
609 | END | |
b8012afd CS |
610 | ; |
611 | ||
612 | } | |
613 | ||
8ad457eb | 614 | print CONFIGFILE <<END |
27731caa CS |
615 | logger_syslog=-1 |
616 | logger_syslog_level=$wlanapsettings{'SYSLOGLEVEL'} | |
617 | logger_stdout=-1 | |
54359730 | 618 | logger_stdout_level=$wlanapsettings{'DEBUG'} |
27731caa | 619 | dump_file=/tmp/hostapd.dump |
7d30ef24 | 620 | auth_algs=1 |
27731caa CS |
621 | ctrl_interface=/var/run/hostapd |
622 | ctrl_interface_group=0 | |
70a7c454 | 623 | disassoc_low_ack=1 |
27731caa CS |
624 | END |
625 | ; | |
54359730 CS |
626 | if ( $wlanapsettings{'HIDESSID'} eq 'on' ){ |
627 | print CONFIGFILE <<END | |
628 | ssid=$wlanapsettings{'SSID'} | |
629 | ignore_broadcast_ssid=2 | |
630 | END | |
631 | ; | |
632 | ||
633 | }else{ | |
634 | print CONFIGFILE <<END | |
635 | ssid=$wlanapsettings{'SSID'} | |
636 | ignore_broadcast_ssid=0 | |
637 | END | |
638 | ; | |
639 | ||
640 | } | |
92f2665d | 641 | |
5b4464a9 PM |
642 | # https://forum.ipfire.org/viewtopic.php?f=22&t=12274&p=79070#p79070 |
643 | if ( $wlanapsettings{'CLIENTISOLATION'} eq 'on' ){ | |
644 | print CONFIGFILE <<END | |
645 | ap_isolate=1 | |
646 | END | |
647 | ; | |
648 | } | |
649 | ||
d823d5f0 AF |
650 | if ( $wlanapsettings{'NOSCAN'} eq 'on' ){ |
651 | print CONFIGFILE <<END | |
652 | noscan=1 | |
653 | END | |
654 | ; | |
655 | ||
656 | }else{ | |
657 | print CONFIGFILE <<END | |
658 | noscan=0 | |
659 | END | |
660 | ; | |
661 | ||
662 | } | |
663 | ||
8c2f203c CS |
664 | if ( $wlanapsettings{'ENC'} eq 'wpa1'){ |
665 | print CONFIGFILE <<END | |
666 | ######################### wpa hostapd configuration ############################ | |
891b6138 | 667 | # |
8c2f203c CS |
668 | wpa=1 |
669 | wpa_passphrase=$wlanapsettings{'PWD'} | |
891b6138 | 670 | wpa_key_mgmt=WPA-PSK |
e62efbb7 | 671 | wpa_pairwise=TKIP |
8c2f203c CS |
672 | END |
673 | ; | |
674 | }elsif ( $wlanapsettings{'ENC'} eq 'wpa2'){ | |
54359730 CS |
675 | print CONFIGFILE <<END |
676 | ######################### wpa hostapd configuration ############################ | |
891b6138 | 677 | # |
8c2f203c | 678 | wpa=2 |
54359730 | 679 | wpa_passphrase=$wlanapsettings{'PWD'} |
891b6138 | 680 | wpa_key_mgmt=WPA-PSK |
e62efbb7 AF |
681 | rsn_pairwise=CCMP |
682 | END | |
683 | ; | |
684 | } elsif ( $wlanapsettings{'ENC'} eq 'wpa1+2'){ | |
685 | print CONFIGFILE <<END | |
686 | ######################### wpa hostapd configuration ############################ | |
687 | # | |
688 | wpa=3 | |
689 | wpa_passphrase=$wlanapsettings{'PWD'} | |
690 | wpa_key_mgmt=WPA-PSK | |
691 | wpa_pairwise=TKIP | |
692 | rsn_pairwise=CCMP | |
54359730 CS |
693 | END |
694 | ; | |
695 | } | |
27731caa | 696 | close CONFIGFILE; |
92f2665d | 697 | |
8aa49c15 | 698 | open (MACFILE, ">/var/ipfire/wlanap/macfile"); |
23e368ab CS |
699 | foreach(@macs){ |
700 | $_ =~ s/\r//gi; | |
701 | chomp($_); | |
702 | if ( $_ ne "" ){print MACFILE $_;} | |
703 | } | |
92f2665d | 704 | close MACFILE; |
27731caa | 705 | } |