setApp($app); } public function setApp(MessageComponentInterface $app) { $this->app = $app; return $this; } public function onOpen(ConnectionInterface $connection) { $request = $connection->httpRequest; $queryParameters = []; parse_str($request->getUri()->getQuery(), $queryParameters); $this->warn("New connection opened for app key {$queryParameters['appKey']}."); $this->app->onOpen(ConnectionLogger::decorate($connection)); } public function onMessage(ConnectionInterface $connection, MessageInterface $message) { $this->info("{$connection->appId}: connection id {$connection->socketId} received message: {$message->getPayload()}."); $this->app->onMessage(ConnectionLogger::decorate($connection), $message); } public function onClose(ConnectionInterface $connection) { $this->warn("{$connection->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->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); } }