Files
kiri-core/HttpServer/Events/OnRequest.php
T

118 lines
2.8 KiB
PHP
Raw Normal View History

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-12-16 17:48:01 +08:00
use HttpServer\Exception\ExitException;
2020-08-31 01:27:08 +08:00
use HttpServer\Http\Request as HRequest;
use HttpServer\Http\Response as HResponse;
2020-12-17 10:12:54 +08:00
use ReflectionException;
2021-03-09 10:24:04 +08:00
use Snowflake\Core\Json;
2021-03-16 10:53:40 +08:00
use Snowflake\Error\Logger;
2020-09-02 15:45:52 +08:00
use Snowflake\Event;
2020-11-27 14:57:58 +08:00
use Snowflake\Exception\ComponentException;
2020-12-17 10:12:54 +08:00
use Snowflake\Exception\NotFindClassException;
2020-08-31 01:27:08 +08:00
use Snowflake\Snowflake;
2021-02-24 14:32:10 +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
{
2021-03-16 10:53:40 +08:00
public Event $event;
public Logger $logger;
/**
* @throws Exception
*/
public function init()
{
$this->event = Snowflake::app()->getEvent();
$this->logger = Snowflake::app()->getLogger();
}
const BEFORE_REQUEST = 'beforeRequest';
const AFTER_REQUEST = 'afterRequest';
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
*/
2021-01-07 14:09:59 +08:00
public function onHandler(Request $request, Response $response): mixed
2020-08-31 01:27:08 +08:00
{
try {
2021-03-16 10:53:40 +08:00
$this->event->trigger(self::BEFORE_REQUEST, [$request]);
2021-02-25 14:33:34 +08:00
[$request, $response] = static::create($request, $response);
2021-02-25 14:53:55 +08:00
if (!$request->is('favicon.ico')) {
return \router()->dispatch();
2021-01-04 18:21:37 +08:00
}
2021-03-16 10:53:40 +08:00
2021-02-25 14:53:55 +08:00
return \send(null);
2021-01-04 18:21:37 +08:00
} catch (ExitException | Error | \Throwable $exception) {
if ($exception instanceof ExitException) {
2021-03-09 10:24:04 +08:00
return \send(Json::to($exception->getCode(), $exception->getMessage()));
2020-09-02 18:43:23 +08:00
}
2021-02-25 14:42:26 +08:00
return $this->sendErrorMessage($request, $response, $exception);
2021-03-16 10:53:40 +08:00
} finally {
$this->event->trigger(Event::SYSTEM_RESOURCE_RELEASES);
$this->event->trigger(self::AFTER_REQUEST, [$request]);
$this->logger->insert();
2020-09-02 15:45:52 +08:00
}
}
2020-11-27 14:26:34 +08:00
2020-12-17 10:12:54 +08:00
/**
* @param $request
* @param $response
* @return array
* @throws NotFindClassException
* @throws ReflectionException
*/
2021-01-04 18:21:37 +08:00
public static function create($request, $response): array
2020-12-17 10:12:54 +08:00
{
return [HRequest::create($request), HResponse::create($response)];
}
2020-09-10 13:42:08 +08:00
/**
2021-02-25 14:42:26 +08:00
* @param $sRequest
* @param $sResponse
2020-09-02 15:45:52 +08:00
* @param $exception
2020-12-16 16:59:33 +08:00
* @return bool|string
2020-12-02 11:36:45 +08:00
* @throws ComponentException
2020-09-02 15:45:52 +08:00
* @throws Exception
*/
2021-02-25 14:42:26 +08:00
protected function sendErrorMessage($sRequest, $sResponse, $exception): bool|string
2020-09-02 15:45:52 +08:00
{
2021-02-25 14:53:55 +08:00
$this->error($exception);
2021-02-25 14:42:26 +08:00
$params = Snowflake::app()->getLogger()->exception($exception);
if ($sResponse instanceof Response) {
2021-02-25 14:53:55 +08:00
[$sRequest, $sResponse] = [HRequest::create($sRequest), HResponse::create($sResponse)];
2021-02-25 14:42:26 +08:00
}
2020-12-16 16:59:33 +08:00
$sResponse->addHeader('Access-Control-Allow-Origin', '*');
$sResponse->addHeader('Access-Control-Allow-Headers', $sRequest->headers->get('access-control-request-headers'));
$sResponse->addHeader('Access-Control-Request-Method', $sRequest->headers->get('access-control-request-method'));
return $sResponse->send($params, 200);
2020-08-31 01:27:08 +08:00
}
}