mirror of
https://github.com/billz/raspap-webgui.git
synced 2023-10-10 13:37:24 +02:00
Change method of calculating channel and security
This commit is contained in:
parent
fe3b0e9513
commit
c7ed97dd8b
@ -5,121 +5,121 @@
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
function DisplayWPAConfig(){
|
function DisplayWPAConfig(){
|
||||||
$status = '';
|
$status = '';
|
||||||
?>
|
?>
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-lg-12">
|
<div class="col-lg-12">
|
||||||
<div class="panel panel-primary">
|
<div class="panel panel-primary">
|
||||||
<div class="panel-heading"><i class="fa fa-signal fa-fw"></i> Configure client
|
<div class="panel-heading"><i class="fa fa-signal fa-fw"></i> Configure client
|
||||||
</div>
|
</div>
|
||||||
<!-- /.panel-heading -->
|
<!-- /.panel-heading -->
|
||||||
<div class="panel-body">
|
<div class="panel-body">
|
||||||
<?php echo $status; ?>
|
<?php echo $status; ?>
|
||||||
<h4>Client settings</h4>
|
<h4>Client settings</h4>
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-lg-12">
|
<div class="col-lg-12">
|
||||||
|
|
||||||
<?php
|
<?php
|
||||||
// save WPA settings
|
// save WPA settings
|
||||||
if( isset($_POST['SaveWPAPSKSettings']) ) {
|
if( isset($_POST['SaveWPAPSKSettings']) ) {
|
||||||
|
|
||||||
$config = 'ctrl_interface=DIR='. RASPI_WPA_CTRL_INTERFACE .' GROUP=netdev
|
$config = 'ctrl_interface=DIR='. RASPI_WPA_CTRL_INTERFACE .' GROUP=netdev
|
||||||
update_config=1
|
update_config=1
|
||||||
';
|
';
|
||||||
$networks = $_POST['Networks'];
|
$networks = $_POST['Networks'];
|
||||||
for( $x = 0; $x < $networks; $x++ ) {
|
for( $x = 0; $x < $networks; $x++ ) {
|
||||||
$network = '';
|
$network = '';
|
||||||
$ssid = escapeshellarg( $_POST['ssid'.$x] );
|
$ssid = escapeshellarg( $_POST['ssid'.$x] );
|
||||||
$psk = escapeshellarg( $_POST['psk'.$x] );
|
$psk = escapeshellarg( $_POST['psk'.$x] );
|
||||||
|
|
||||||
if ( strlen($psk) >2 ) {
|
if ( strlen($psk) >2 ) {
|
||||||
exec( 'wpa_passphrase '.$ssid. ' ' . $psk,$network );
|
exec( 'wpa_passphrase '.$ssid. ' ' . $psk,$network );
|
||||||
foreach($network as $b) {
|
foreach($network as $b) {
|
||||||
$config .= "$b
|
$config .= "$b
|
||||||
";
|
";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
exec( "echo '$config' > /tmp/wifidata", $return );
|
exec( "echo '$config' > /tmp/wifidata", $return );
|
||||||
system( 'sudo cp /tmp/wifidata ' . RASPI_WPA_SUPPLICANT_CONFIG, $returnval );
|
system( 'sudo cp /tmp/wifidata ' . RASPI_WPA_SUPPLICANT_CONFIG, $returnval );
|
||||||
if( $returnval == 0 ) {
|
if( $returnval == 0 ) {
|
||||||
echo '<div class="alert alert-success alert-dismissable">Wifi settings updated successfully
|
echo '<div class="alert alert-success alert-dismissable">Wifi settings updated successfully
|
||||||
<button type="button" class="close" data-dismiss="alert" aria-hidden="true">×</button></div>';
|
<button type="button" class="close" data-dismiss="alert" aria-hidden="true">×</button></div>';
|
||||||
} else {
|
} else {
|
||||||
echo '<div class="alert alert-danger alert-dismissable">Wifi settings failed to be updated
|
echo '<div class="alert alert-danger alert-dismissable">Wifi settings failed to be updated
|
||||||
<button type="button" class="close" data-dismiss="alert" aria-hidden="true">×</button></div>';
|
<button type="button" class="close" data-dismiss="alert" aria-hidden="true">×</button></div>';
|
||||||
}
|
}
|
||||||
|
|
||||||
// scan networks
|
// scan networks
|
||||||
} elseif( isset($_POST['Scan']) ) {
|
} elseif( isset($_POST['Scan']) ) {
|
||||||
$return = '';
|
$return = '';
|
||||||
exec( 'sudo wpa_cli scan',$return );
|
exec( 'sudo wpa_cli scan',$return );
|
||||||
sleep(3);
|
sleep(3);
|
||||||
exec( 'sudo wpa_cli scan_results',$return );
|
exec( 'sudo wpa_cli scan_results',$return );
|
||||||
for( $shift = 0; $shift < 4; $shift++ ) {
|
for( $shift = 0; $shift < 4; $shift++ ) {
|
||||||
array_shift($return);
|
array_shift($return);
|
||||||
}
|
}
|
||||||
// display output
|
// display output
|
||||||
echo '<form method="POST" action="?page=wpa_conf" id="wpa_conf_form"><input type="hidden" id="Networks" name="Networks" /><div class="network" id="networkbox"></div>';
|
echo '<form method="POST" action="?page=wpa_conf" id="wpa_conf_form"><input type="hidden" id="Networks" name="Networks" /><div class="network" id="networkbox"></div>';
|
||||||
echo '<div class="row"><div class="col-lg-6"><input type="submit" class="btn btn-primary" value="Scan for networks" name="Scan" /> <input type="button" class="btn btn-primary" value="Add network" onClick="AddNetwork();" /> <input type="submit" class="btn btn-primary" value="Save" name="SaveWPAPSKSettings" onmouseover="UpdateNetworks(this)" id="Save" disabled /></div></div>';
|
echo '<div class="row"><div class="col-lg-6"><input type="submit" class="btn btn-primary" value="Scan for networks" name="Scan" /> <input type="button" class="btn btn-primary" value="Add network" onClick="AddNetwork();" /> <input type="submit" class="btn btn-primary" value="Save" name="SaveWPAPSKSettings" onmouseover="UpdateNetworks(this)" id="Save" disabled /></div></div>';
|
||||||
echo '<h4>Networks found</h4><div class="table-responsive"><table class="table table-hover">';
|
echo '<h4>Networks found</h4><div class="table-responsive"><table class="table table-hover">';
|
||||||
echo '<thead><tr><th></th><th>SSID</th><th>Channel</th><th>Signal</th><th>Security</th></tr></thead><tbody>';
|
echo '<thead><tr><th></th><th>SSID</th><th>Channel</th><th>Signal</th><th>Security</th></tr></thead><tbody>';
|
||||||
foreach( $return as $network ) {
|
foreach( $return as $network ) {
|
||||||
$arrNetwork = preg_split("/[\t]+/",$network);
|
$arrNetwork = preg_split("/[\t]+/",$network);
|
||||||
$bssid = $arrNetwork[0];
|
$bssid = $arrNetwork[0];
|
||||||
$channel = ConvertToChannel($arrNetwork[1]);
|
$channel = ConvertToChannel($arrNetwork[1]);
|
||||||
$signal = $arrNetwork[2] . " dBm";
|
$signal = $arrNetwork[2] . " dBm";
|
||||||
$security = $arrNetwork[3];
|
$security = $arrNetwork[3];
|
||||||
$ssid = $arrNetwork[4];
|
$ssid = $arrNetwork[4];
|
||||||
echo '<tr><td><input type="button" class="btn btn-outline btn-primary" value="Connect" onClick="AddScanned(\''.$ssid.'\')" /></td> <td><strong>' . $ssid . "</strong></td> <td>" . $channel . "</td><td>" . $signal . "</td><td>". ConvertToSecurity($security) ."</td></tr>";
|
echo '<tr><td><input type="button" class="btn btn-outline btn-primary" value="Connect" onClick="AddScanned(\''.$ssid.'\')" /></td> <td><strong>' . $ssid . "</strong></td> <td>" . $channel . "</td><td>" . $signal . "</td><td>". ConvertToSecurity($security) ."</td></tr>";
|
||||||
}
|
}
|
||||||
echo '</tbody></table>';
|
echo '</tbody></table>';
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
// default action, output configured network(s)
|
// default action, output configured network(s)
|
||||||
exec(' sudo cat ' . RASPI_WPA_SUPPLICANT_CONFIG, $return);
|
exec(' sudo cat ' . RASPI_WPA_SUPPLICANT_CONFIG, $return);
|
||||||
$ssid = array();
|
$ssid = array();
|
||||||
$psk = array();
|
$psk = array();
|
||||||
|
|
||||||
foreach($return as $a) {
|
foreach($return as $a) {
|
||||||
if(preg_match('/SSID/i',$a)) {
|
if(preg_match('/SSID/i',$a)) {
|
||||||
$arrssid = explode("=",$a);
|
$arrssid = explode("=",$a);
|
||||||
$ssid[] = str_replace('"','',$arrssid[1]);
|
$ssid[] = str_replace('"','',$arrssid[1]);
|
||||||
}
|
}
|
||||||
if(preg_match('/psk/i',$a)) {
|
if(preg_match('/psk/i',$a)) {
|
||||||
$arrpsk = explode("=",$a);
|
$arrpsk = explode("=",$a);
|
||||||
$psk[] = str_replace('"','',$arrpsk[1]);
|
$psk[] = str_replace('"','',$arrpsk[1]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$numSSIDs = count($ssid);
|
$numSSIDs = count($ssid);
|
||||||
$output = '<form method="POST" action="?page=wpa_conf" id="wpa_conf_form"><input type="hidden" id="Networks" name="Networks" /><div class="network" id="networkbox">';
|
$output = '<form method="POST" action="?page=wpa_conf" id="wpa_conf_form"><input type="hidden" id="Networks" name="Networks" /><div class="network" id="networkbox">';
|
||||||
|
|
||||||
if ( $numSSIDs > 0 ) {
|
if ( $numSSIDs > 0 ) {
|
||||||
for( $ssids = 0; $ssids < $numSSIDs; $ssids++ ) {
|
for( $ssids = 0; $ssids < $numSSIDs; $ssids++ ) {
|
||||||
$output .= '<div id="Networkbox'.$ssids.'" class="NetworkBoxes">
|
$output .= '<div id="Networkbox'.$ssids.'" class="NetworkBoxes">
|
||||||
<div class="row"><div class="form-group col-md-4"><label for="code">Network '.$ssids.'</label></div></div>
|
<div class="row"><div class="form-group col-md-4"><label for="code">Network '.$ssids.'</label></div></div>
|
||||||
<div class="row"><div class="form-group col-md-4"><label for="code" id="lssid0">SSID</label><input type="text" class="form-control" id="ssid0" name="ssid'.$ssids.'" value="'.$ssid[$ssids].'" onkeyup="CheckSSID(this)" /></div></div>
|
<div class="row"><div class="form-group col-md-4"><label for="code" id="lssid0">SSID</label><input type="text" class="form-control" id="ssid0" name="ssid'.$ssids.'" value="'.$ssid[$ssids].'" onkeyup="CheckSSID(this)" /></div></div>
|
||||||
<div class="row"><div class="form-group col-md-4"><label for="code" id="lpsk0">PSK</label><input type="password" class="form-control" id="psk0" name="psk'.$ssids.'" value="'.$psk[$ssids].'" onkeyup="CheckPSK(this)" /></div></div>
|
<div class="row"><div class="form-group col-md-4"><label for="code" id="lpsk0">PSK</label><input type="password" class="form-control" id="psk0" name="psk'.$ssids.'" value="'.$psk[$ssids].'" onkeyup="CheckPSK(this)" /></div></div>
|
||||||
<div class="row"><div class="form-group col-md-4"><input type="button" class="btn btn-outline btn-primary" value="Delete" onClick="DeleteNetwork('.$ssids.')" /></div></div>';
|
<div class="row"><div class="form-group col-md-4"><input type="button" class="btn btn-outline btn-primary" value="Delete" onClick="DeleteNetwork('.$ssids.')" /></div></div>';
|
||||||
}
|
}
|
||||||
$output .= '</div><!-- /#Networkbox -->';
|
$output .= '</div><!-- /#Networkbox -->';
|
||||||
} else {
|
} else {
|
||||||
$status = '<div class="alert alert-warning alert-dismissable">Not connected
|
$status = '<div class="alert alert-warning alert-dismissable">Not connected
|
||||||
<button type="button" class="close" data-dismiss="alert" aria-hidden="true">×</button></div>';
|
<button type="button" class="close" data-dismiss="alert" aria-hidden="true">×</button></div>';
|
||||||
}
|
}
|
||||||
$output .= '<div class="row"><div class="col-lg-6"><input type="submit" class="btn btn-primary" value="Scan for networks" name="Scan" /> <input type="button" class="btn btn-primary" value="Add network" onClick="AddNetwork();" /> <input type="submit" class="btn btn-primary" value="Save" name="SaveWPAPSKSettings" onmouseover="UpdateNetworks(this)" id="Save" disabled />';
|
$output .= '<div class="row"><div class="col-lg-6"><input type="submit" class="btn btn-primary" value="Scan for networks" name="Scan" /> <input type="button" class="btn btn-primary" value="Add network" onClick="AddNetwork();" /> <input type="submit" class="btn btn-primary" value="Save" name="SaveWPAPSKSettings" onmouseover="UpdateNetworks(this)" id="Save" disabled />';
|
||||||
$output .= '</form>';
|
$output .= '</form>';
|
||||||
echo $output;
|
echo $output;
|
||||||
}
|
}
|
||||||
?>
|
?>
|
||||||
<script type="text/Javascript">UpdateNetworks(this)</script>
|
<script type="text/Javascript">UpdateNetworks(this)</script>
|
||||||
</form>
|
</form>
|
||||||
</div><!-- ./ Panel body -->
|
</div><!-- ./ Panel body -->
|
||||||
</div><!-- /.panel-primary -->
|
</div><!-- /.panel-primary -->
|
||||||
</div><!-- /.col-lg-12 -->
|
</div><!-- /.col-lg-12 -->
|
||||||
</div><!-- /.row -->
|
</div><!-- /.row -->
|
||||||
<?php
|
<?php
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -85,18 +85,12 @@ function ParseConfig( $arrConfig ) {
|
|||||||
* @return $channel
|
* @return $channel
|
||||||
*/
|
*/
|
||||||
function ConvertToChannel( $freq ) {
|
function ConvertToChannel( $freq ) {
|
||||||
|
$channel = ($freq - 2407)/5;
|
||||||
$base = 2412;
|
if ($channel > 0 && $channel < 14) {
|
||||||
$channel = 1;
|
return $channel;
|
||||||
for( $x = 0; $x < 13; $x++ ) {
|
} else {
|
||||||
if( $freq != $base ) {
|
return 'Invalid Channel';
|
||||||
$base = $base + 5;
|
}
|
||||||
$channel++;
|
|
||||||
} else {
|
|
||||||
return $channel;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return "Invalid Channel";
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -105,36 +99,28 @@ function ConvertToChannel( $freq ) {
|
|||||||
* @return string
|
* @return string
|
||||||
*/
|
*/
|
||||||
function ConvertToSecurity( $security ) {
|
function ConvertToSecurity( $security ) {
|
||||||
|
$options = array();
|
||||||
switch( $security ) {
|
preg_match_all('/\[([^\]]+)\]/s', $security, $matches);
|
||||||
case "[WPA2-PSK-CCMP][ESS]":
|
foreach($matches[1] as $match) {
|
||||||
return "WPA2-PSK (AES)";
|
if (preg_match('/^(WPA\d?)/', $match, $protocol_match)) {
|
||||||
break;
|
$protocol = $protocol_match[1];
|
||||||
case "[WPA2-PSK-TKIP][ESS]":
|
$matchArr = explode('-', $match);
|
||||||
return "WPA2-PSK (TKIP)";
|
if (count($matchArr) > 2) {
|
||||||
break;
|
$options[] = $protocol . ' ('. $matchArr[2] .')';
|
||||||
case "[WPA2-PSK-CCMP][WPS][ESS]":
|
} else {
|
||||||
return "WPA/WPA2-PSK (TKIP/AES)";
|
$options[] = $protocol;
|
||||||
break;
|
}
|
||||||
case "[WPA2-PSK-TKIP+CCMP][WPS][ESS]":
|
}
|
||||||
return "WPA2-PSK (TKIP/AES) with WPS";
|
}
|
||||||
break;
|
|
||||||
case "[WPA-PSK-TKIP+CCMP][WPS][ESS]":
|
if (count($options) === 0) {
|
||||||
return "WPA-PSK (TKIP/AES) with WPS";
|
// This could also be WEP but wpa_supplicant doesn't have a way to determine
|
||||||
break;
|
// this.
|
||||||
case "[WPA-PSK-TKIP][WPA2-PSK-CCMP][WPS][ESS]":
|
// And you shouldn't be using WEP these days anyway.
|
||||||
return "WPA/WPA2-PSK (TKIP/AES)";
|
return 'Open';
|
||||||
break;
|
} else {
|
||||||
case "[WPA-PSK-TKIP+CCMP][WPA2-PSK-TKIP+CCMP][ESS]":
|
return implode('<br />', $options);
|
||||||
return "WPA/WPA2-PSK (TKIP/AES)";
|
}
|
||||||
break;
|
|
||||||
case "[WPA-PSK-TKIP][ESS]":
|
|
||||||
return "WPA-PSK (TKIP)";
|
|
||||||
break;
|
|
||||||
case "[WEP][ESS]":
|
|
||||||
return "WEP";
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
Reference in New Issue
Block a user