Skip to content

Commit

Permalink
Do not try to resolve hostname of clients in long-term data
Browse files Browse the repository at this point in the history
Signed-off-by: Christian König <[email protected]>
  • Loading branch information
yubiuser committed Oct 22, 2021
1 parent 49c84e5 commit 2561cbf
Showing 1 changed file with 4 additions and 39 deletions.
43 changes: 4 additions & 39 deletions api_db.php
Original file line number Diff line number Diff line change
Expand Up @@ -18,37 +18,6 @@
ini_set("max_execution_time","600");

$data = array();
$clients = array();
function resolveHostname($clientip, $printIP)
{
global $clients;
$ipaddr = strtolower($clientip);
if(array_key_exists($clientip, $clients))
{
// Entry already exists
$clientname = $clients[$ipaddr];
if($printIP)
return $clientname."|".$clientip;
return $clientname;
}

else if(validIP($clientip))
{
// Get host name of client and convert to lower case
$clientname = strtolower(gethostbyaddr($ipaddr));
}
else
{
// This is already a host name
$clientname = $ipaddr;
}
// Buffer result
$clients[$ipaddr] = $clientname;

if($printIP)
return $clientname."|".$clientip;
return $clientname;
}

// Needs package php5-sqlite, e.g.
// sudo apt-get install php5-sqlite
Expand Down Expand Up @@ -121,15 +90,12 @@ function resolveHostname($clientip, $printIP)
if(!is_bool($results))
while ($row = $results->fetchArray())
{
// Try to resolve host name of this client
$c = resolveHostname($row[3],false);

// Convert query type ID to name
$query_type = getQueryTypeStr($row[1]);

// Insert into array
// array: time type domain client status upstream destination
$allQueries[] = [$row[0], $query_type, utf8_encode(str_replace("~"," ",$row[2])), utf8_encode($c), $row[4], utf8_encode($row[5])];
$allQueries[] = [$row[0], $query_type, utf8_encode(str_replace("~"," ",$row[2])), $row[3], $row[4], utf8_encode($row[5])];
}
}
$result = array('data' => $allQueries);
Expand Down Expand Up @@ -162,18 +128,17 @@ function resolveHostname($clientip, $printIP)
if(!is_bool($results))
while ($row = $results->fetchArray())
{
// Try to resolve host name and convert to UTF-8
$c = utf8_encode(resolveHostname($row[0],false));
// $row[0] is the client IP

if(array_key_exists($c, $clientnums))
if(array_key_exists($row[0], $clientnums))
{
// Entry already exists, add to it (might appear multiple times due to mixed capitalization in the database)
$clientnums[$c] += intval($row[1]);
}
else
{
// Entry does not yet exist
$clientnums[$c] = intval($row[1]);
$clientnums[$row[0]] = intval($row[1]);
}
}

Expand Down

0 comments on commit 2561cbf

Please sign in to comment.