diff --git a/config/app.php b/config/app.php index 480c3426..12b0c2a6 100644 --- a/config/app.php +++ b/config/app.php @@ -177,6 +177,7 @@ * breathing room to complete logging or error handling. */ 'Error' => [ + 'logger' => App\Error\ExtendedErrorLogger::class, 'errorLevel' => E_ALL, 'skipLog' => [], 'log' => true, diff --git a/src/Error/ExtendedErrorLogger.php b/src/Error/ExtendedErrorLogger.php new file mode 100644 index 00000000..30e22ef9 --- /dev/null +++ b/src/Error/ExtendedErrorLogger.php @@ -0,0 +1,62 @@ +getRequestTarget(); + + $referer = $request->getHeaderLine('Referer'); + if ($referer) { + $message .= "\nReferer URL: " . $referer; + } + + + if (method_exists($request, 'clientIp')) { + $clientIp = $request->clientIp(); + if ($clientIp && $clientIp !== '::1') { + $message .= "\nClient IP: " . $clientIp; + } + } + + if (!empty($_SERVER['HTTP_X_FORWARDED_FOR'])) { + $message .= sprintf( + "\nClient X_FORWARDED_FOR: %s", + $_SERVER['HTTP_X_FORWARDED_FOR'] + ); + } + + if (!empty($request->getSession()->read('authUser'))) { + $message .= sprintf( + "\nClient user: #%s :: %s", + $request->getSession()->read('authUser.id'), + $request->getSession()->read('authUser.username') + ); + } + return $message; + } +} \ No newline at end of file