2020-08-31 01:27:08 +08:00
|
|
|
<?php
|
2020-10-29 18:17:25 +08:00
|
|
|
declare(strict_types=1);
|
2020-08-31 01:27:08 +08:00
|
|
|
|
|
|
|
|
namespace HttpServer\Events;
|
|
|
|
|
|
|
|
|
|
|
2020-09-02 11:38:47 +08:00
|
|
|
use Exception;
|
2020-09-04 01:05:33 +08:00
|
|
|
use HttpServer\Abstracts\Callback;
|
2020-08-31 01:27:08 +08:00
|
|
|
use HttpServer\Http\Context;
|
|
|
|
|
use HttpServer\Http\Request as HRequest;
|
|
|
|
|
use HttpServer\Http\Response as HResponse;
|
2020-09-08 11:53:09 +08:00
|
|
|
use HttpServer\Route\Node;
|
2020-09-02 11:38:47 +08:00
|
|
|
use HttpServer\Service\Http;
|
2020-09-17 11:15:35 +08:00
|
|
|
use Snowflake\Abstracts\Config;
|
2020-08-31 01:27:08 +08:00
|
|
|
use Snowflake\Core\JSON;
|
2020-09-02 15:45:52 +08:00
|
|
|
use Snowflake\Event;
|
2020-08-31 01:27:08 +08:00
|
|
|
use Snowflake\Snowflake;
|
2020-09-09 11:05:28 +08:00
|
|
|
use Swoole\Coroutine;
|
2020-08-31 01:27:08 +08:00
|
|
|
use Swoole\Error;
|
|
|
|
|
use Swoole\Http\Request;
|
|
|
|
|
use Swoole\Http\Response;
|
|
|
|
|
|
2020-09-02 11:38:47 +08:00
|
|
|
/**
|
|
|
|
|
* Class OnRequest
|
|
|
|
|
* @package HttpServer\Events
|
|
|
|
|
*/
|
|
|
|
|
class OnRequest extends Callback
|
2020-08-31 01:27:08 +08:00
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @param Request $request
|
|
|
|
|
* @param Response $response
|
2020-09-02 18:43:23 +08:00
|
|
|
* @return void
|
2020-09-02 11:38:47 +08:00
|
|
|
* @throws Exception
|
2020-08-31 01:27:08 +08:00
|
|
|
*/
|
|
|
|
|
public function onHandler(Request $request, Response $response)
|
|
|
|
|
{
|
|
|
|
|
try {
|
2020-10-30 11:04:04 +08:00
|
|
|
Coroutine::defer(function () {
|
|
|
|
|
fire(Event::EVENT_AFTER_REQUEST, [$sRequest ?? null]);
|
|
|
|
|
});
|
2020-09-17 11:15:35 +08:00
|
|
|
if (Config::get('debug.enable', false, false)) {
|
|
|
|
|
function_exists('trackerHookMalloc') && trackerHookMalloc();
|
|
|
|
|
}
|
2020-09-02 18:43:23 +08:00
|
|
|
/** @var HRequest $sRequest */
|
2020-09-15 18:36:28 +08:00
|
|
|
[$sRequest, $sResponse] = [HRequest::create($request), HResponse::create($response)];
|
2020-09-02 18:43:23 +08:00
|
|
|
if ($sRequest->is('favicon.ico')) {
|
2020-10-30 11:04:04 +08:00
|
|
|
$sResponse->send($sRequest->isNotFound(), 200);
|
|
|
|
|
} else {
|
|
|
|
|
Snowflake::app()->getRouter()->dispatch();
|
2020-09-02 18:43:23 +08:00
|
|
|
}
|
2020-08-31 01:27:08 +08:00
|
|
|
} catch (Error | \Throwable $exception) {
|
2020-10-30 11:04:04 +08:00
|
|
|
$this->sendErrorMessage($sResponse ?? null, $exception, $response);
|
2020-09-02 15:45:52 +08:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-09-10 13:42:08 +08:00
|
|
|
/**
|
|
|
|
|
* @param $response
|
|
|
|
|
* @throws Exception
|
|
|
|
|
*/
|
|
|
|
|
public static function shutdown($response)
|
|
|
|
|
{
|
|
|
|
|
$error = error_get_last();
|
|
|
|
|
if (!isset($error['type'])) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
$types = [E_ERROR, E_PARSE, E_CORE_ERROR, E_COMPILE_ERROR];
|
|
|
|
|
if (!in_array($error['type'], $types)) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
try {
|
|
|
|
|
$message = $error['message'] . ':' . microtime(true);
|
|
|
|
|
if ($response instanceof Response) {
|
|
|
|
|
$response->status(500);
|
|
|
|
|
$response->end($message);
|
|
|
|
|
}
|
|
|
|
|
} catch (\ErrorException $exception) {
|
|
|
|
|
$logger = Snowflake::app()->logger;
|
|
|
|
|
$logger->write($exception->getMessage(), 'shutdown');
|
|
|
|
|
}
|
|
|
|
|
unset($response);
|
|
|
|
|
}
|
2020-09-02 15:45:52 +08:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @param $sResponse
|
|
|
|
|
* @param $exception
|
|
|
|
|
* @param $response
|
2020-09-09 11:26:25 +08:00
|
|
|
* @return false|int|mixed|string
|
2020-09-02 15:45:52 +08:00
|
|
|
* @throws Exception
|
|
|
|
|
*/
|
|
|
|
|
protected function sendErrorMessage($sResponse, $exception, $response)
|
|
|
|
|
{
|
2020-09-09 12:08:07 +08:00
|
|
|
$params = Snowflake::app()->getLogger()->exception($exception);
|
2020-09-02 15:45:52 +08:00
|
|
|
if (empty($sResponse)) {
|
2020-09-09 11:26:25 +08:00
|
|
|
$sResponse = \response();
|
|
|
|
|
$sResponse->response = $response;
|
2020-08-31 01:27:08 +08:00
|
|
|
}
|
2020-09-09 11:26:25 +08:00
|
|
|
return $sResponse->send($params, 200);
|
2020-08-31 01:27:08 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|