mirror of
https://github.com/pi-hole/web.git
synced 2025-12-25 13:06:20 +00:00
* Add api_db.php?getGraphData Signed-off-by: DL6ER <dl6er@dl6er.de> * Add new DB Graph page Signed-off-by: DL6ER <dl6er@dl6er.de> * Adjust x-axis format Signed-off-by: DL6ER <dl6er@dl6er.de> * Tweaks to long term stats (#543) * add maxDate to Datepicker * remove `GO` Button from datepicker input, instead hook into the apply event to update the graphs/charts when the date range is selected * :codacy: Signed-off-by: DL6ER <dl6er@dl6er.de> * Fix comment + another :codacy: * Remove duplicated code * Add click callback to DB graph that sends the user to the DB query log page. This required some re-write of the DB queries page. * Remove uneeded global variable * Remove minDate and MaxDate as it is causing issues on fresh installs * Oh :codacy: ...
217 lines
6.2 KiB
PHP
217 lines
6.2 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;
|
|
header('Content-type: application/json');
|
|
require("scripts/pi-hole/php/password.php");
|
|
require("scripts/pi-hole/php/auth.php");
|
|
check_cors();
|
|
|
|
$data = array();
|
|
|
|
// Needs package php5-sqlite, e.g.
|
|
// sudo apt-get install php5-sqlite
|
|
|
|
$db = new SQLite3('/etc/pihole/pihole-FTL.db');
|
|
if(!$db)
|
|
die("Cannot access database");
|
|
|
|
// Long-Term API functions
|
|
// if (isset($_GET['test']))
|
|
// {
|
|
// // $results = $db->query('SELECT * FROM QUERIES order by TIMESTAMP ASC LIMIT 2');
|
|
// $results = $db->query('SELECT TIMESTAMP,TYPE,DOMAIN,CLIENT,STATUS FROM QUERIES order by TIMESTAMP ASC');
|
|
// echo "N=".$result->numColumns;
|
|
// while ($row = $results->fetchArray())
|
|
// var_dump($row);
|
|
// }
|
|
|
|
if (isset($_GET['getAllQueries']) && $auth)
|
|
{
|
|
if($_GET['getAllQueries'] === "empty")
|
|
{
|
|
$allQueries = array();
|
|
}
|
|
else
|
|
{
|
|
$from = intval($_GET["from"]);
|
|
$until = intval($_GET["until"]);
|
|
$results = $db->query('SELECT timestamp,type,domain,client,status FROM queries WHERE timestamp >= '.$from.' AND timestamp <= '.$until.' ORDER BY timestamp ASC');
|
|
$allQueries = array();
|
|
while ($row = $results->fetchArray())
|
|
{
|
|
$allQueries[] = [$row[0],$row[1] == 1 ? "IPv4" : "IPv6",$row[2],$row[3],$row[4]];
|
|
}
|
|
}
|
|
$result = array('data' => $allQueries);
|
|
$data = array_merge($data, $result);
|
|
}
|
|
|
|
if (isset($_GET['topClients']) && $auth)
|
|
{
|
|
// $from = intval($_GET["from"]);
|
|
$limit = "";
|
|
if(isset($_GET["from"]) && isset($_GET["until"]))
|
|
{
|
|
$limit = "WHERE timestamp >= ".$_GET["from"]." AND timestamp <= ".$_GET["until"];
|
|
}
|
|
elseif(isset($_GET["from"]) && !isset($_GET["until"]))
|
|
{
|
|
$limit = "WHERE timestamp >= ".$_GET["from"];
|
|
}
|
|
elseif(!isset($_GET["from"]) && isset($_GET["until"]))
|
|
{
|
|
$limit = "WHERE timestamp <= ".$_GET["until"];
|
|
}
|
|
$results = $db->query('SELECT client,count(client) FROM queries '.$limit.' GROUP by client order by count(client) desc limit 10');
|
|
$clients = array();
|
|
while ($row = $results->fetchArray())
|
|
{
|
|
$clients[$row[0]] = intval($row[1]);
|
|
// var_dump($row);
|
|
}
|
|
$result = array('top_sources' => $clients);
|
|
$data = array_merge($data, $result);
|
|
}
|
|
|
|
if (isset($_GET['topDomains']) && $auth)
|
|
{
|
|
$limit = "";
|
|
|
|
if(isset($_GET["from"]) && isset($_GET["until"]))
|
|
{
|
|
$limit = " AND timestamp >= ".$_GET["from"]." AND timestamp <= ".$_GET["until"];
|
|
}
|
|
elseif(isset($_GET["from"]) && !isset($_GET["until"]))
|
|
{
|
|
$limit = " AND timestamp >= ".$_GET["from"];
|
|
}
|
|
elseif(!isset($_GET["from"]) && isset($_GET["until"]))
|
|
{
|
|
$limit = " AND timestamp <= ".$_GET["until"];
|
|
}
|
|
$results = $db->query('SELECT domain,count(domain) FROM queries WHERE (STATUS == 2 OR STATUS == 3)'.$limit.' GROUP by domain order by count(domain) desc limit 10');
|
|
$domains = array();
|
|
while ($row = $results->fetchArray())
|
|
{
|
|
$domains[$row[0]] = intval($row[1]);
|
|
}
|
|
$result = array('top_domains' => $domains);
|
|
$data = array_merge($data, $result);
|
|
}
|
|
|
|
if (isset($_GET['topAds']) && $auth)
|
|
{
|
|
$limit = "";
|
|
|
|
if(isset($_GET["from"]) && isset($_GET["until"]))
|
|
{
|
|
$limit = " AND timestamp >= ".$_GET["from"]." AND timestamp <= ".$_GET["until"];
|
|
}
|
|
elseif(isset($_GET["from"]) && !isset($_GET["until"]))
|
|
{
|
|
$limit = " AND timestamp >= ".$_GET["from"];
|
|
}
|
|
elseif(!isset($_GET["from"]) && isset($_GET["until"]))
|
|
{
|
|
$limit = " AND timestamp <= ".$_GET["until"];
|
|
}
|
|
$results = $db->query('SELECT domain,count(domain) FROM queries WHERE (STATUS == 1 OR STATUS == 4)'.$limit.' GROUP by domain order by count(domain) desc limit 10');
|
|
$addomains = array();
|
|
while ($row = $results->fetchArray())
|
|
{
|
|
$addomains[$row[0]] = intval($row[1]);
|
|
}
|
|
$result = array('top_ads' => $addomains);
|
|
$data = array_merge($data, $result);
|
|
}
|
|
|
|
if (isset($_GET['getMinTimestamp']) && $auth)
|
|
{
|
|
$results = $db->query('SELECT MIN(timestamp) FROM queries');
|
|
$result = array('mintimestamp' => $results->fetchArray()[0]);
|
|
$data = array_merge($data, $result);
|
|
}
|
|
|
|
if (isset($_GET['getMaxTimestamp']) && $auth)
|
|
{
|
|
$results = $db->query('SELECT MAX(timestamp) FROM queries');
|
|
$result = array('maxtimestamp' => $results->fetchArray()[0]);
|
|
$data = array_merge($data, $result);
|
|
}
|
|
|
|
if (isset($_GET['getQueriesCount']) && $auth)
|
|
{
|
|
$results = $db->query('SELECT COUNT(timestamp) FROM queries');
|
|
$result = array('count' => $results->fetchArray()[0]);
|
|
$data = array_merge($data, $result);
|
|
}
|
|
|
|
if (isset($_GET['getDBfilesize']) && $auth)
|
|
{
|
|
$filesize = filesize("/etc/pihole/pihole-FTL.db");
|
|
$result = array('filesize' => $filesize);
|
|
$data = array_merge($data, $result);
|
|
}
|
|
|
|
if (isset($_GET['getGraphData']) && $auth)
|
|
{
|
|
$limit = "";
|
|
|
|
if(isset($_GET["from"]) && isset($_GET["until"]))
|
|
{
|
|
$limit = " AND timestamp >= ".intval($_GET["from"])." AND timestamp <= ".intval($_GET["until"]);
|
|
}
|
|
elseif(isset($_GET["from"]) && !isset($_GET["until"]))
|
|
{
|
|
$limit = " AND timestamp >= ".intval($_GET["from"]);
|
|
}
|
|
elseif(!isset($_GET["from"]) && isset($_GET["until"]))
|
|
{
|
|
$limit = " AND timestamp <= ".intval($_GET["until"]);
|
|
}
|
|
|
|
$interval = 600;
|
|
|
|
if(isset($_GET["interval"]))
|
|
{
|
|
$q = intval($_GET["interval"]);
|
|
if($q > 10)
|
|
$interval = $q;
|
|
}
|
|
|
|
// Count permitted queries in intervals
|
|
$results = $db->query('SELECT (timestamp/'.$interval.')*'.$interval.' interval, COUNT(*) FROM queries WHERE (status == 2 OR status == 3)'.$limit.' GROUP by interval ORDER by interval');
|
|
$domains = array();
|
|
while ($row = $results->fetchArray())
|
|
{
|
|
$domains[$row[0]] = intval($row[1]);
|
|
}
|
|
$result = array('domains_over_time' => $domains);
|
|
$data = array_merge($data, $result);
|
|
|
|
// Count blocked queries in intervals
|
|
$results = $db->query('SELECT (timestamp/'.$interval.')*'.$interval.' interval, COUNT(*) FROM queries WHERE (status == 1 OR status == 4 OR status == 5)'.$limit.' GROUP by interval ORDER by interval');
|
|
$addomains = array();
|
|
while ($row = $results->fetchArray())
|
|
{
|
|
$addomains[$row[0]] = intval($row[1]);
|
|
}
|
|
$result = array('ads_over_time' => $addomains);
|
|
$data = array_merge($data, $result);
|
|
}
|
|
|
|
if(isset($_GET["jsonForceObject"]))
|
|
{
|
|
echo json_encode($data, JSON_FORCE_OBJECT);
|
|
}
|
|
else
|
|
{
|
|
echo json_encode($data);
|
|
}
|