diff --git a/scripts/pi-hole/php/FTL.php b/scripts/pi-hole/php/FTL.php index caddd758..df356753 100644 --- a/scripts/pi-hole/php/FTL.php +++ b/scripts/pi-hole/php/FTL.php @@ -26,7 +26,7 @@ function sendRequestFTL($requestin) global $socket; $request = ">".$requestin; - fwrite($socket, $request) or die("Could not send data to server\n"); + fwrite($socket, $request) or die('{"error":"Could not send data to server"}'); } function getResponseFTL() @@ -35,9 +35,16 @@ function getResponseFTL() $response = []; + $errCount = 0; while(true) { $out = fgets($socket); + file_put_contents('/tmp/pihole.txt', $out, FILE_APPEND); + if ($out == "") $errCount++; + if ($errCount > 100) { + // Tried 100 times, but never got proper reply, fail to prevent busy loop + die('{"error":"Tried 100 times to connect to FTL server, but never got proper reply. Please check Port and logs!"}'); + } if(strrpos($out,"---EOM---") !== false) break; diff --git a/scripts/pi-hole/php/auth.php b/scripts/pi-hole/php/auth.php index 1ea6014d..56f84520 100644 --- a/scripts/pi-hole/php/auth.php +++ b/scripts/pi-hole/php/auth.php @@ -10,6 +10,14 @@ require_once('func.php'); $ERRORLOG = getenv('PHP_ERROR_LOG'); if (empty($ERRORLOG)) { $ERRORLOG = '/var/log/lighttpd/error.log'; + + if (!file_exists($ERRORLOG) || !is_writable($ERRORLOG)) { + $ERRORLOG = '/var/log/apache2/error.log'; + + if (!file_exists($ERRORLOG) || !is_writable($ERRORLOG)) { + $ERRORLOG = '/tmp/pi-hole-error.log'; + } + } } function pi_log($message) {