security->getUser(); $data->setUser($user); $provider = $data->getProvider(); $this->logger->info('User {username} wants to register a connector from provider {provider}.', [ 'username' => $user->getUserIdentifier(), 'provider' => $provider->value, ]); if (null === $provider) { throw new BadRequestHttpException('Provider not found'); } $authData = $data->getAuthData(); if (ConnectorProvider::EPP === $provider) { $filesystem = new Filesystem(); $directory = EppClientProvider::buildEppCertificateFolder($this->kernel->getProjectDir(), $data->getId()); unset($authData['file_certificate_pem'], $authData['file_certificate_key']); // Prevent alteration from user if (isset($authData['certificate_pem'], $authData['certificate_key'])) { $pemPath = $directory.'client.pem'; $keyPath = $directory.'client.key'; $filesystem->mkdir($directory, 0755); $filesystem->dumpFile($pemPath, $authData['certificate_pem']); $filesystem->dumpFile($keyPath, $authData['certificate_key']); $data->setAuthData([...$authData, 'file_certificate_pem' => $pemPath, 'file_certificate_key' => $keyPath]); } /** @var AbstractProvider $providerClient */ $providerClient = $this->locator->get($provider->getConnectorProvider()); try { $data->setAuthData($providerClient->authenticate($authData)); } catch (\Throwable $exception) { $filesystem->remove($directory); throw $exception; } } else { /** @var AbstractProvider $providerClient */ $providerClient = $this->locator->get($provider->getConnectorProvider()); $data->setAuthData($providerClient->authenticate($authData)); } $this->logger->info('User {username} authentication data with the {provider} provider has been validated.', [ 'username' => $user->getUserIdentifier(), 'provider' => $provider->value, ]); $data->setCreatedAt(new \DateTimeImmutable('now')); $this->persistProcessor->process($data, $operation, $uriVariables, $context); return $data; } }