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

56 lines
987 B
PHP
Raw Normal View History

2020-09-02 11:38:47 +08:00
<?php
2020-10-29 18:17:25 +08:00
declare(strict_types=1);
2020-09-02 11:38:47 +08:00
namespace HttpServer\Events;
2020-09-04 01:05:33 +08:00
use HttpServer\Abstracts\Callback;
2020-09-02 11:38:47 +08:00
use Snowflake\Event;
use Snowflake\Snowflake;
use Swoole\Server;
use Exception;
/**
* Class OnClose
* @package HttpServer\Events
2020-11-06 16:48:57 +08:00
*
2020-09-02 11:38:47 +08:00
*/
class OnClose extends Callback
{
/**
* @param Server $server
* @param int $fd
* @throws Exception
*/
public function onHandler(Server $server, int $fd)
2020-11-27 14:57:58 +08:00
{
2021-03-08 18:40:42 +08:00
try {
2021-03-31 16:52:39 +08:00
$clientInfo = $server->getClientInfo($fd);
$event = Snowflake::app()->getEvent();
if (!$event->exists(($name = $this->getName($clientInfo)))) {
return;
}
$event->trigger($name, [$fd, $server]);
2021-03-08 18:40:42 +08:00
} catch (\Throwable $exception) {
2021-03-31 16:52:39 +08:00
$this->addError($exception, 'throwable');
2021-03-08 18:40:42 +08:00
} finally {
fire(Event::SYSTEM_RESOURCE_RELEASES);
2021-04-07 14:17:24 +08:00
logger_insert();
2021-03-08 18:40:42 +08:00
}
2020-11-27 14:57:58 +08:00
}
2021-03-08 18:29:59 +08:00
/**
* @param $server_port
* @return string
*/
2021-03-31 16:52:39 +08:00
private function getName($server_port): string
2021-03-08 18:29:59 +08:00
{
2021-03-31 18:00:44 +08:00
return 'listen ' . $server_port['server_port'] . ' ' . Event::SERVER_CLIENT_CLOSE;
2021-03-08 18:29:59 +08:00
}
2020-09-02 11:38:47 +08:00
}