is('favicon.ico')) { $params = $sResponse->send($sRequest->isNotFound(), 200); } else { $params = Snowflake::app()->getRouter()->dispatch(); } } catch (Error | \Throwable $exception) { $params = $this->sendErrorMessage($sResponse ?? null, $exception, $response); } finally { $events = Snowflake::app()->getEvent(); if (!$events->exists(Event::EVENT_AFTER_REQUEST)) { return; } $events->trigger(Event::EVENT_AFTER_REQUEST, [$sRequest, $params]); } } /** * @param $sResponse * @param $exception * @param $response * @return false|int|mixed|string * @throws Exception */ protected function sendErrorMessage($sResponse, $exception, $response) { $params = $this->format($exception); if (empty($sResponse)) { $sResponse = \response(); $sResponse->response = $response; } return $sResponse->send($params, 200); } /** * @param Exception $exception * @return false|int|mixed|string * @throws Exception */ public function format($exception) { $errorInfo = [ 'message' => $exception->getMessage(), 'file' => $exception->getFile(), 'line' => $exception->getLine() ]; $this->error(var_export($errorInfo, true)); $code = $exception->getCode() ?? 500; $logger = Snowflake::app()->logger; $string = 'Exception: ' . PHP_EOL; $string .= '#. message: ' . $errorInfo['message'] . PHP_EOL; $string .= '#. file: ' . $errorInfo['file'] . PHP_EOL; $string .= '#. line: ' . $errorInfo['line'] . PHP_EOL; $logger->write($string . $exception->getTraceAsString(), 'trace'); $logger->write(jTraceEx($exception), 'exception'); return JSON::to($code, $errorInfo['message']); } /** * @param $request * @param $response * @return array * @throws Exception */ public static function setContext($request, $response): array { $request = Context::setContext('request', HRequest::create($request)); $response = Context::setContext('response', HResponse::create($response)); return [$request, $response]; } }