Fechar conexões não autenticadas
Problema:
Como fechar clientes que não enviaram dados dentro de um período especificado,
por exemplo, fechar a conexão automaticamente se não receber nenhum dado em 30 segundos,
com o objetivo de garantir que conexões não autenticadas se autentiquem dentro do tempo estipulado.
Resposta:
use Workerman\Worker;
use Workerman\Timer;
use Workerman\Connection\TcpConnection;
require_once __DIR__ . '/vendor/autoload.php';
$worker = new Worker('xxx://x.x.x.x:x');
$worker->onConnect = function(TcpConnection $connection)
{
// Temporariamente adiciona uma propriedade auth_timer_id ao objeto $connection para armazenar o ID do timer
// Cria um timer de 30 segundos para fechar a conexão, o cliente precisa enviar a autenticação dentro de 30 segundos para remover o timer
$connection->auth_timer_id = Timer::add(30, function()use($connection){
$connection->close();
}, null, false);
};
$worker->onMessage = function(TcpConnection $connection, $msg)
{
$msg = json_decode($msg, true);
switch($msg['type'])
{
case 'login':
...略
// Autenticação bem-sucedida, remove o timer para evitar que a conexão seja fechada
Timer::del($connection->auth_timer_id);
break;
... 略
}
... 略
}