2020-08-31 01:27:08 +08:00
|
|
|
<?php
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
namespace HttpServer\Events;
|
|
|
|
|
|
|
|
|
|
|
2020-09-02 11:38:47 +08:00
|
|
|
use Exception;
|
|
|
|
|
use HttpServer\Events\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-02 11:38:47 +08:00
|
|
|
use HttpServer\Service\Http;
|
2020-08-31 01:27:08 +08:00
|
|
|
use Snowflake\Core\JSON;
|
|
|
|
|
use Snowflake\Snowflake;
|
|
|
|
|
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 11:38:47 +08:00
|
|
|
* @throws Exception
|
2020-08-31 01:27:08 +08:00
|
|
|
*/
|
|
|
|
|
public function onHandler(Request $request, Response $response)
|
|
|
|
|
{
|
|
|
|
|
try {
|
|
|
|
|
[$sRequest, $sResponse] = static::setContext($request, $response);
|
|
|
|
|
$sResponse->send(Snowflake::get()->router->dispatch(), 200);
|
|
|
|
|
} catch (Error | \Throwable $exception) {
|
|
|
|
|
if (!isset($sResponse)) {
|
|
|
|
|
$response->status(200);
|
|
|
|
|
$response->end($exception->getMessage());
|
|
|
|
|
} else {
|
|
|
|
|
$sResponse->send($this->format($exception), 200);
|
|
|
|
|
}
|
|
|
|
|
} finally {
|
|
|
|
|
$dividing_line = str_pad('', 100, '-');
|
2020-09-02 11:38:47 +08:00
|
|
|
$this->debug($dividing_line, 'app');
|
2020-08-31 01:27:08 +08:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @param $exception
|
|
|
|
|
* @return false|int|mixed|string
|
|
|
|
|
* @throws Exception
|
|
|
|
|
*/
|
|
|
|
|
public function format($exception)
|
|
|
|
|
{
|
|
|
|
|
$errorInfo = [
|
|
|
|
|
'message' => $exception->getMessage(),
|
|
|
|
|
'file' => $exception->getFile(),
|
|
|
|
|
'line' => $exception->getLine()
|
|
|
|
|
];
|
2020-09-02 11:38:47 +08:00
|
|
|
$this->error(var_export($errorInfo, true));
|
2020-08-31 01:27:08 +08:00
|
|
|
|
|
|
|
|
$code = $exception->getCode() ?? 500;
|
|
|
|
|
$trance = array_slice($exception->getTrace(), 0, 10);
|
|
|
|
|
Snowflake::get()->logger->write(print_r($trance, true), '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];
|
|
|
|
|
}
|
|
|
|
|
|
2020-09-02 11:38:47 +08:00
|
|
|
|
2020-08-31 01:27:08 +08:00
|
|
|
}
|