connection = $connection; $this->configurationRepository = $configurationRepository; $this->encrypter = $encrypter; $this->repository = $repository; } /** * Update the configuration values for a given node on the machine. * * @param \Pterodactyl\Models\Node $node * @param array $data * @param bool $resetToken * * @return \Pterodactyl\Models\Node * @throws \Throwable */ public function handle(Node $node, array $data, bool $resetToken = false) { if ($resetToken) { $data['daemon_token'] = $this->encrypter->encrypt(Str::random(Node::DAEMON_TOKEN_LENGTH)); $data['daemon_token_id'] = Str::random(Node::DAEMON_TOKEN_ID_LENGTH); } [$updated, $exception] = $this->connection->transaction(function () use ($data, $node) { /** @var \Pterodactyl\Models\Node $updated */ $updated = $this->repository->withFreshModel()->update($node->id, $data, true, true); try { // If we're changing the FQDN for the node, use the newly provided FQDN for the connection // address. This should alleviate issues where the node gets pointed to a "valid" FQDN that // isn't actually running the daemon software, and therefore you can't actually change it // back. // // This makes more sense anyways, because only the Panel uses the FQDN for connecting, the // node doesn't actually care about this. // // @see https://github.com/pterodactyl/panel/issues/1931 if (! empty($data['fqdn'])) { $node->fqdn = $data['fqdn']; } $this->configurationRepository->setNode($node)->update($updated); } catch (DaemonConnectionException $exception) { if (! is_null($exception->getPrevious()) && $exception->getPrevious() instanceof ConnectException) { return [$updated, true]; } throw $exception; } return [$updated, false]; }); if ($exception) { throw new ConfigurationNotPersistedException(trans('exceptions.node.daemon_off_config_updated')); } return $updated; } }