mirror of
https://github.com/billz/raspap-webgui.git
synced 2023-10-10 13:37:24 +02:00
da69d3d768
update the page's CSRF tokens with the new token from the response header, verify csrf token in ajax endpoints, initialize a session for every endpoint
90 lines
2.7 KiB
PHP
90 lines
2.7 KiB
PHP
<?php
|
|
|
|
require('includes/csrf.php');
|
|
|
|
require_once '../../includes/config.php';
|
|
require_once RASPI_CONFIG.'/raspap.php';
|
|
|
|
header('X-Frame-Options: DENY');
|
|
header("Content-Security-Policy: default-src 'none'; connect-src 'self'");
|
|
require_once '../../includes/authenticate.php';
|
|
|
|
|
|
$interface = filter_input(INPUT_GET, 'inet', FILTER_SANITIZE_SPECIAL_CHARS);
|
|
if (empty($interface)) {
|
|
// Use first interface if inet parameter not provided.
|
|
exec("ip -o link show | awk -F ': ' '{print $2}' | grep -v lo ", $interfacesWlo);
|
|
if (count($interfacesWlo) > 0) {
|
|
$interface = $interfacesWlo[0];
|
|
} else {
|
|
exit('No network interfaces found.');
|
|
}
|
|
}
|
|
|
|
define('IFNAMSIZ', 16);
|
|
if (strlen($interface) > IFNAMSIZ) {
|
|
exit('Interface name too long.');
|
|
} elseif(!preg_match('/^[a-zA-Z0-9]+$/', $interface)) {
|
|
exit('Invalid interface name.');
|
|
}
|
|
|
|
require_once './get_bandwidth_hourly.php';
|
|
|
|
exec(sprintf('vnstat -i %s --json ', escapeshellarg($interface)), $jsonstdoutvnstat,
|
|
$exitcodedaily);
|
|
if ($exitcodedaily !== 0) {
|
|
exit('vnstat error');
|
|
}
|
|
|
|
$jsonobj = json_decode($jsonstdoutvnstat[0], true);
|
|
$timeunits = filter_input(INPUT_GET, 'tu');
|
|
if ($timeunits === 'm') {
|
|
// months
|
|
$jsonData = $jsonobj['interfaces'][0]['traffic']['months'];
|
|
} else {
|
|
// default: days
|
|
$jsonData = $jsonobj['interfaces'][0]['traffic']['days'];
|
|
}
|
|
|
|
$datasizeunits = filter_input(INPUT_GET, 'dsu');
|
|
header('X-Content-Type-Options: nosniff');
|
|
header('Content-Type: application/json');
|
|
echo '[ ';
|
|
$firstelm = true;
|
|
for ($i = count($jsonData) - 1; $i >= 0; --$i) {
|
|
if ($timeunits === 'm') {
|
|
$dt = DateTime::createFromFormat('Y n', $jsonData[$i]['date']['year'].' '.
|
|
$jsonData[$i]['date']['month']);
|
|
} else {
|
|
$dt = DateTime::createFromFormat('Y n j', $jsonData[$i]['date']['year'].' '.
|
|
$jsonData[$i]['date']['month'].' '.
|
|
$jsonData[$i]['date']['day']);
|
|
}
|
|
|
|
if ($firstelm) {
|
|
$firstelm = false;
|
|
} else {
|
|
echo ',';
|
|
}
|
|
|
|
if ($datasizeunits == 'mb') {
|
|
$datasend = round($jsonData[$i]['tx'] / 1024, 0);
|
|
$datareceived = round($jsonData[$i]['rx'] / 1024, 0);
|
|
} else {
|
|
$datasend = $jsonData[$i]['rx'];
|
|
$datareceived = $jsonData[$i]['rx'];
|
|
}
|
|
|
|
if ($timeunits === 'm') {
|
|
echo '{ "date": "' , $dt->format('Y-m') , '", "rx": "' , $datareceived ,
|
|
'", "tx": "' , $datasend , '" }';
|
|
} else {
|
|
echo '{ "date": "' , $dt->format('Y-m-d') , '", "rx": "' , $datareceived ,
|
|
'", "tx": "' , $datasend , '" }';
|
|
}
|
|
}
|
|
|
|
echo ' ]';
|
|
|
|
|