mirror of
https://github.com/pi-hole/web.git
synced 2025-12-24 12:48:29 +00:00
243 lines
4.8 KiB
PHP
243 lines
4.8 KiB
PHP
<?php
|
|
/* Pi-hole: A black hole for Internet advertisements
|
|
* (c) 2017 Pi-hole, LLC (https://pi-hole.net)
|
|
* Network-wide ad blocking via your own hardware.
|
|
*
|
|
* This file is copyright under the latest version of the EUPL.
|
|
* Please see LICENSE file for your rights under this license */
|
|
|
|
$api = true;
|
|
|
|
require("scripts/pi-hole/php/FTL.php");
|
|
if(!testFTL())
|
|
{
|
|
require("api_PHP.php");
|
|
exit();
|
|
}
|
|
|
|
require "scripts/pi-hole/php/password.php";
|
|
require "scripts/pi-hole/php/auth.php";
|
|
|
|
check_cors();
|
|
$socket = connectFTL("127.0.0.1");
|
|
header('Content-type: application/json');
|
|
|
|
$data = [];
|
|
|
|
if (isset($_GET['summary']) || isset($_GET['summaryRaw']))
|
|
{
|
|
sendRequestFTL("stats");
|
|
$return = getResponseFTL();
|
|
|
|
$stats = [];
|
|
foreach($return as $line)
|
|
{
|
|
$tmp = explode(" ",$line);
|
|
|
|
if(isset($_GET['summary']))
|
|
{
|
|
if($tmp[0] !== "ads_percentage_today")
|
|
{
|
|
$stats[$tmp[0]] = number_format($tmp[1]);
|
|
}
|
|
else
|
|
{
|
|
$stats[$tmp[0]] = number_format($tmp[1], 1, '.', '');
|
|
}
|
|
}
|
|
else
|
|
{
|
|
$stats[$tmp[0]] = $tmp[1];
|
|
}
|
|
}
|
|
$data = array_merge($data,$stats);
|
|
}
|
|
|
|
if (isset($_GET['overTimeData10mins']))
|
|
{
|
|
sendRequestFTL("overTime");
|
|
$return = getResponseFTL();
|
|
|
|
$domains_over_time = array();
|
|
$ads_over_time = array();
|
|
foreach($return as $line)
|
|
{
|
|
$tmp = explode(" ",$line);
|
|
$domains_over_time[$tmp[0]] = $tmp[1];
|
|
$ads_over_time[$tmp[0]] = $tmp[2];
|
|
}
|
|
$result = array('domains_over_time' => $domains_over_time,
|
|
'ads_over_time' => $ads_over_time);
|
|
$data = array_merge($data, $result);
|
|
}
|
|
|
|
if (isset($_GET['topItems']) && $auth)
|
|
{
|
|
if(is_numeric($_GET['topItems']))
|
|
{
|
|
sendRequestFTL("top-domains ".$_GET['topItems']);
|
|
}
|
|
else
|
|
{
|
|
sendRequestFTL("top-domains");
|
|
}
|
|
|
|
$return = getResponseFTL();
|
|
$top_queries = array();
|
|
foreach($return as $line)
|
|
{
|
|
$tmp = explode(" ",$line);
|
|
$top_queries[$tmp[2]] = $tmp[1];
|
|
}
|
|
|
|
if(is_numeric($_GET['topItems']))
|
|
{
|
|
sendRequestFTL("top-ads ".$_GET['topItems']);
|
|
}
|
|
else
|
|
{
|
|
sendRequestFTL("top-ads");
|
|
}
|
|
|
|
$return = getResponseFTL();
|
|
$top_ads = array();
|
|
foreach($return as $line)
|
|
{
|
|
$tmp = explode(" ",$line);
|
|
$top_ads[$tmp[2]] = $tmp[1];
|
|
}
|
|
|
|
$result = array('top_queries' => $top_queries,
|
|
'top_ads' => $top_ads);
|
|
|
|
$data = array_merge($data, $result);
|
|
}
|
|
|
|
if ((isset($_GET['topClients']) || isset($_GET['getQuerySources'])) && $auth)
|
|
{
|
|
sendRequestFTL("top-clients");
|
|
$return = getResponseFTL();
|
|
$top_clients = array();
|
|
foreach($return as $line)
|
|
{
|
|
$tmp = explode(" ",$line);
|
|
if(count($tmp) == 4)
|
|
{
|
|
$top_clients[$tmp[3]."|".$tmp[2]] = $tmp[1];
|
|
}
|
|
else
|
|
{
|
|
$top_clients[$tmp[2]] = $tmp[1];
|
|
}
|
|
}
|
|
|
|
$result = array('top_sources' => $top_clients);
|
|
$data = array_merge($data, $result);
|
|
}
|
|
|
|
if (isset($_GET['getForwardDestinations']) && $auth)
|
|
{
|
|
sendRequestFTL("forward-dest");
|
|
$return = getResponseFTL();
|
|
$forward_dest = array();
|
|
foreach($return as $line)
|
|
{
|
|
$tmp = explode(" ",$line);
|
|
if(count($tmp) == 4)
|
|
{
|
|
$forward_dest[$tmp[3]."|".$tmp[2]] = $tmp[1];
|
|
}
|
|
else
|
|
{
|
|
$forward_dest[$tmp[2]] = $tmp[1];
|
|
}
|
|
}
|
|
|
|
$result = array('forward_destinations' => $forward_dest);
|
|
$data = array_merge($data, $result);
|
|
}
|
|
|
|
if (isset($_GET['getQueryTypes']) && $auth)
|
|
{
|
|
sendRequestFTL("querytypes");
|
|
$return = getResponseFTL();
|
|
$querytypes = array();
|
|
foreach($return as $ret)
|
|
{
|
|
$tmp = explode(": ",$ret);
|
|
$querytypes[$tmp[0]] = $tmp[1];
|
|
}
|
|
|
|
$result = array('querytypes' => $querytypes);
|
|
$data = array_merge($data, $result);
|
|
}
|
|
|
|
if (isset($_GET['getAllQueries']) && $auth)
|
|
{
|
|
if(isset($_GET['from']) && isset($_GET['until']))
|
|
{
|
|
// Get limited time interval
|
|
sendRequestFTL("getallqueries-time ".$_GET['from']." ".$_GET['until']);
|
|
}
|
|
else if(isset($_GET['domain']))
|
|
{
|
|
// Get specific domain only
|
|
sendRequestFTL("getallqueries-domain ".$_GET['domain']);
|
|
}
|
|
else if(isset($_GET['client']))
|
|
{
|
|
// Get specific client only
|
|
sendRequestFTL("getallqueries-client ".$_GET['client']);
|
|
}
|
|
else
|
|
{
|
|
// Get all queries
|
|
sendRequestFTL("getallqueries");
|
|
}
|
|
$return = getResponseFTL();
|
|
$allQueries = array();
|
|
foreach($return as $line)
|
|
{
|
|
$tmp = explode(" ",$line);
|
|
array_push($allQueries,$tmp);
|
|
}
|
|
|
|
$result = array('data' => $allQueries);
|
|
$data = array_merge($data, $result);
|
|
}
|
|
|
|
if (isset($_GET['enable'], $_GET['token']) && $auth) {
|
|
check_csrf($_GET['token']);
|
|
exec('sudo pihole enable');
|
|
$data = array_merge($data, array("status" => "enabled"));
|
|
}
|
|
elseif (isset($_GET['disable'], $_GET['token']) && $auth) {
|
|
check_csrf($_GET['token']);
|
|
$disable = intval($_GET['disable']);
|
|
// intval returns the integer value on success, or 0 on failure
|
|
if($disable > 0)
|
|
{
|
|
exec("sudo pihole disable ".$disable."s");
|
|
}
|
|
else
|
|
{
|
|
exec('sudo pihole disable');
|
|
}
|
|
$data = array_merge($data, array("status" => "disabled"));
|
|
}
|
|
|
|
if(isset($_GET["recentBlocked"]))
|
|
{
|
|
sendRequestFTL("recentBlocked");
|
|
echo getResponseFTL()[0];
|
|
unset($data);
|
|
}
|
|
|
|
if(isset($data))
|
|
{
|
|
echo json_encode($data);
|
|
}
|
|
|
|
disconnectFTL();
|
|
?>
|