2019-08-19 01:04:53 +02:00
|
|
|
<?php
|
|
|
|
$arrHostapdConf = parse_ini_file('/etc/raspap/hostapd.ini');
|
|
|
|
if ($arrHostapdConf['WifiAPEnable'] == 1) {
|
2019-09-07 17:42:31 +02:00
|
|
|
$client_iface = 'uap0';
|
2019-08-19 01:04:53 +02:00
|
|
|
} else {
|
2019-09-07 17:42:31 +02:00
|
|
|
$client_iface = RASPI_WIFI_CLIENT_INTERFACE;
|
2019-08-19 01:04:53 +02:00
|
|
|
}
|
|
|
|
exec('cat '.RASPI_DNSMASQ_LEASES.'| grep -E $(arp -i '.$client_iface.' -n | grep -oE "(([0-9]|[a-f]|[A-F]){2}:){5}([0-9]|[a-f]|[A-F]){2}" | tr "\n" "\|" | sed "s/.$//")', $clients);
|
2019-11-01 10:08:49 +01:00
|
|
|
$ifaceStatus = $wlan0up ? "up" : "down";
|
2019-08-19 01:04:53 +02:00
|
|
|
?>
|
|
|
|
<div class="row">
|
|
|
|
<div class="col-lg-12">
|
2019-10-11 21:37:59 +02:00
|
|
|
<div class="card">
|
2019-10-14 22:18:16 +02:00
|
|
|
<div class="card-header">
|
|
|
|
<div class="row">
|
|
|
|
<div class="col">
|
|
|
|
<i class="fas fa-tachometer-alt fa-fw mr-2"></i><?php echo _("Dashboard"); ?>
|
|
|
|
</div>
|
|
|
|
<div class="col">
|
|
|
|
<button class="btn btn-light btn-icon-split btn-sm service-status float-right">
|
2019-10-20 19:31:39 +02:00
|
|
|
<span class="icon"><i class="fas fa-circle service-status-<?php echo $ifaceStatus ?>"></i></span>
|
2019-11-01 10:08:49 +01:00
|
|
|
<span class="text service-status"><?php echo strtolower($client_iface) .' '. _($ifaceStatus) ?></span>
|
2019-10-14 22:18:16 +02:00
|
|
|
</button>
|
|
|
|
</div>
|
|
|
|
</div><!-- /.row -->
|
|
|
|
</div><!-- /.card-header -->
|
2019-10-11 21:37:59 +02:00
|
|
|
<div class="card-body">
|
2019-08-19 01:04:53 +02:00
|
|
|
<div class="row">
|
2019-10-14 12:32:40 +02:00
|
|
|
<div class="col-md-6 mb-3">
|
|
|
|
<div class="card h-100">
|
|
|
|
<div class="card-body wireless">
|
|
|
|
<h4><?php echo _("Wireless Information"); ?></h4>
|
2019-10-15 01:01:22 +02:00
|
|
|
<div class="info-item"><?php echo _("Connected To"); ?></div><div><?php echo htmlspecialchars($connectedSSID, ENT_QUOTES); ?></div>
|
|
|
|
<div class="info-item"><?php echo _("AP Mac Address"); ?></div><div><?php echo htmlspecialchars($connectedBSSID, ENT_QUOTES); ?></div>
|
|
|
|
<div class="info-item"><?php echo _("Bitrate"); ?></div><div><?php echo htmlspecialchars($bitrate, ENT_QUOTES); ?></div>
|
|
|
|
<div class="info-item"><?php echo _("Signal Level"); ?></div><div><?php echo htmlspecialchars($signalLevel, ENT_QUOTES); ?></div>
|
|
|
|
<div class="info-item"><?php echo _("Transmit Power"); ?></div><div><?php echo htmlspecialchars($txPower, ENT_QUOTES); ?></div>
|
|
|
|
<div class="info-item"><?php echo _("Frequency"); ?></div><div><?php echo htmlspecialchars($frequency, ENT_QUOTES); ?></div>
|
2019-10-14 12:32:40 +02:00
|
|
|
<div class="info-item"><?php echo _("Link Quality"); ?></div>
|
2019-10-15 01:04:17 +02:00
|
|
|
<script>var linkQ = <?php echo json_encode($strLinkQuality); ?>;</script>
|
2019-10-14 12:32:40 +02:00
|
|
|
<div class="chart-pie pt-5">
|
2019-11-01 10:08:49 +01:00
|
|
|
<canvas id="canvas" class="chartjs-render-monitor"></canvas>
|
2019-10-14 12:32:40 +02:00
|
|
|
</div>
|
|
|
|
</div><!-- /.card-body -->
|
|
|
|
</div><!-- /.card -->
|
|
|
|
</div><!-- /.col-md-6 -->
|
2019-08-19 01:04:53 +02:00
|
|
|
<div class="col-md-6">
|
2019-10-11 21:37:59 +02:00
|
|
|
<div class="card mb-3">
|
|
|
|
<div class="card-body">
|
2019-08-19 01:04:53 +02:00
|
|
|
<h4><?php echo _("Interface Information"); ?></h4>
|
2019-10-15 01:01:22 +02:00
|
|
|
<div class="info-item"><?php echo _("Interface Name"); ?></div><div><?php echo RASPI_WIFI_CLIENT_INTERFACE; ?></div>
|
|
|
|
<div class="info-item"><?php echo _("IPv4 Address"); ?></div><div><?php echo htmlspecialchars($ipv4Addrs, ENT_QUOTES); ?></div>
|
|
|
|
<div class="info-item"><?php echo _("Subnet Mask"); ?></div><div><?php echo htmlspecialchars($ipv4Netmasks, ENT_QUOTES); ?></div>
|
|
|
|
<div class="info-item"><?php echo _("IPv6 Address"); ?></div><div><?php echo htmlspecialchars($ipv6Addrs, ENT_QUOTES); ?></div>
|
|
|
|
<div class="info-item"><?php echo _("Mac Address"); ?></div><div><?php echo htmlspecialchars($macAddr, ENT_QUOTES); ?></div>
|
2019-10-11 21:37:59 +02:00
|
|
|
</div><!-- /.card-body -->
|
|
|
|
</div><!-- /.card-->
|
|
|
|
<div class="card mb-3">
|
|
|
|
<div class="card-body">
|
2019-08-19 01:04:53 +02:00
|
|
|
<h4><?php echo _("Interface Statistics"); ?></h4>
|
2019-10-15 01:01:22 +02:00
|
|
|
<div class="info-item"><?php echo _("Received Packets"); ?></div><div><?php echo number_format($strRxPackets); ?></div>
|
|
|
|
<div class="info-item"><?php echo _("Received Bytes"); ?></div><div><?php echo number_format($strRxBytes); ?></div>
|
|
|
|
<div class="info-item"><?php echo _("Transferred Packets"); ?></div><div><?php echo number_format($strTxPackets); ?></div>
|
|
|
|
<div class="info-item"><?php echo _("Transferred Bytes"); ?></div><div><?php echo number_format($strTxBytes); ?></div>
|
2019-10-11 21:37:59 +02:00
|
|
|
</div><!-- /.card-body -->
|
|
|
|
</div><!-- /.card -->
|
|
|
|
<div class="card mb-3">
|
|
|
|
<div class="card-body wireless">
|
2019-08-19 01:04:53 +02:00
|
|
|
<h4><?php echo _("Connected Devices"); ?></h4>
|
|
|
|
<div class="table-responsive">
|
|
|
|
<table class="table table-hover">
|
|
|
|
<thead>
|
|
|
|
<tr>
|
|
|
|
<th><?php echo _("Host name"); ?></th>
|
|
|
|
<th><?php echo _("IP Address"); ?></th>
|
|
|
|
<th><?php echo _("MAC Address"); ?></th>
|
|
|
|
</tr>
|
|
|
|
</thead>
|
|
|
|
<tbody>
|
2019-09-07 17:42:31 +02:00
|
|
|
<?php foreach ($clients as $client) : ?>
|
|
|
|
<?php $props = explode(' ', $client) ?>
|
2019-08-19 01:04:53 +02:00
|
|
|
<tr>
|
|
|
|
<td><?php echo htmlspecialchars($props[3], ENT_QUOTES) ?></td>
|
|
|
|
<td><?php echo htmlspecialchars($props[2], ENT_QUOTES) ?></td>
|
|
|
|
<td><?php echo htmlspecialchars($props[1], ENT_QUOTES) ?></td>
|
|
|
|
</tr>
|
2019-09-07 17:42:31 +02:00
|
|
|
<?php endforeach ?>
|
2019-08-19 01:04:53 +02:00
|
|
|
</tbody>
|
|
|
|
</table>
|
|
|
|
</div><!-- /.table-responsive -->
|
2019-10-11 21:37:59 +02:00
|
|
|
</div><!-- /.card-body -->
|
|
|
|
</div><!-- /.card -->
|
2019-08-19 01:04:53 +02:00
|
|
|
</div><!-- /.col-md-6 -->
|
|
|
|
</div><!-- /.row -->
|
|
|
|
|
|
|
|
<div class="col-lg-12">
|
|
|
|
<div class="row">
|
|
|
|
<form action="?page=wlan0_info" method="POST">
|
2019-09-07 17:42:31 +02:00
|
|
|
<?php echo CSRFTokenFieldTag() ?>
|
|
|
|
<?php if (!RASPI_MONITOR_ENABLED) : ?>
|
|
|
|
<?php if (!$wlan0up) : ?>
|
2019-10-22 10:01:01 +02:00
|
|
|
<input type="submit" class="btn btn-success" value="<?php echo _("Start").' '.RASPI_WIFI_CLIENT_INTERFACE ?>" name="ifup_wlan0" />
|
2019-09-07 17:42:31 +02:00
|
|
|
<?php else : ?>
|
2019-10-22 10:01:01 +02:00
|
|
|
<input type="submit" class="btn btn-warning" value="<?php echo _("Stop").' '.RASPI_WIFI_CLIENT_INTERFACE ?>" name="ifdown_wlan0" />
|
2019-09-07 17:42:31 +02:00
|
|
|
<?php endif ?>
|
|
|
|
<?php endif ?>
|
2019-10-11 21:37:59 +02:00
|
|
|
<a href="?page=<?php echo $_GET['page'] ?>" class="btn btn-outline btn-primary"><i class="fas fa-sync-alt"></i> <?php echo _("Refresh") ?></a>
|
2019-08-19 01:04:53 +02:00
|
|
|
</form>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
2019-10-11 21:37:59 +02:00
|
|
|
</div><!-- /.card-body -->
|
2019-10-20 19:31:39 +02:00
|
|
|
<div class="card-footer"><?php echo _("Information provided by ip and iw and from system"); ?></div>
|
2019-10-11 21:37:59 +02:00
|
|
|
</div><!-- /.card -->
|
2019-08-19 01:04:53 +02:00
|
|
|
</div><!-- /.col-lg-12 -->
|
|
|
|
</div><!-- /.row -->
|