setApp($app); } public function setApp(MessageComponentInterface $app) { $this->app = $app; return $this; } public function onOpen(ConnectionInterface $connection) { $appKey = QueryParameters::create($connection->httpRequest)->get('appKey'); $this->warn("New connection opened for app key {$appKey}."); $this->app->onOpen(ConnectionLogger::decorate($connection)); } public function onMessage(ConnectionInterface $connection, MessageInterface $message) { $this->info("{$connection->client->appId}: connection id {$connection->socketId} received message: {$message->getPayload()}."); $this->app->onMessage(ConnectionLogger::decorate($connection), $message); } public function onClose(ConnectionInterface $connection) { $this->warn("{optional($connection->client)->appId}: connection id {$connection->socketId} closed."); $this->app->onClose(ConnectionLogger::decorate($connection)); } public function onError(ConnectionInterface $connection, Exception $exception) { $exceptionClass = get_class($exception); $appId = $connection->client->appId ?? 'Unknown app id'; $message = "{$appId}: exception `{$exceptionClass}` thrown: `{$exception->getMessage()}`"; if ($this->verbose) { $message .= $exception->getTraceAsString(); } $this->error($message); $this->app->onError(ConnectionLogger::decorate($connection), $exception); } }