mirror of
https://github.com/maelgangloff/domain-watchdog.git
synced 2025-12-29 16:15:04 +00:00
feat: EPP protocol implementation
This commit is contained in:
@@ -6,6 +6,7 @@ use App\Config\ConnectorProvider;
|
|||||||
use App\Entity\Connector;
|
use App\Entity\Connector;
|
||||||
use App\Entity\User;
|
use App\Entity\User;
|
||||||
use App\Service\Connector\AbstractProvider;
|
use App\Service\Connector\AbstractProvider;
|
||||||
|
use App\Service\Connector\EppClientProvider;
|
||||||
use Doctrine\Common\Collections\Collection;
|
use Doctrine\Common\Collections\Collection;
|
||||||
use Doctrine\ORM\EntityManagerInterface;
|
use Doctrine\ORM\EntityManagerInterface;
|
||||||
use Psr\Log\LoggerInterface;
|
use Psr\Log\LoggerInterface;
|
||||||
@@ -48,6 +49,7 @@ class ConnectorController extends AbstractController
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @throws \Exception
|
* @throws \Exception
|
||||||
|
* @throws \Throwable
|
||||||
*/
|
*/
|
||||||
#[Route(
|
#[Route(
|
||||||
path: '/api/connectors',
|
path: '/api/connectors',
|
||||||
@@ -81,27 +83,41 @@ class ConnectorController extends AbstractController
|
|||||||
$directory = sprintf('../var/epp-certificates/%s/', $connector->getId());
|
$directory = sprintf('../var/epp-certificates/%s/', $connector->getId());
|
||||||
|
|
||||||
$filesystem = new Filesystem();
|
$filesystem = new Filesystem();
|
||||||
$filesystem->mkdir($directory);
|
$filesystem->mkdir($directory, 0755);
|
||||||
$authData = $connector->getAuthData();
|
$authData = $connector->getAuthData();
|
||||||
|
|
||||||
if (!isset($authData['certificate_pem'], $authData['certificate_key'])) {
|
if (!isset($authData['certificate_pem'], $authData['certificate_key'])) {
|
||||||
throw new BadRequestHttpException('EPP certificates are required');
|
throw new BadRequestHttpException('EPP certificates are required');
|
||||||
}
|
}
|
||||||
|
|
||||||
$pemPath = $directory.'certificate.pem';
|
$pemPath = $directory.'client.pem';
|
||||||
$keyPath = $directory.'certificate.key';
|
$keyPath = $directory.'client.key';
|
||||||
|
|
||||||
$filesystem->dumpFile($pemPath, urldecode($authData['certificate_pem']));
|
$filesystem->dumpFile($pemPath, urldecode($authData['certificate_pem']));
|
||||||
$filesystem->dumpFile($keyPath, urldecode($authData['certificate_key']));
|
$filesystem->dumpFile($keyPath, urldecode($authData['certificate_key']));
|
||||||
|
|
||||||
$connector->setAuthData([...$authData, 'files' => ['pem' => $pemPath, 'key' => $keyPath]]);
|
$connector->setAuthData([...$authData, 'files' => ['pem' => $pemPath, 'key' => $keyPath]]);
|
||||||
}
|
|
||||||
|
|
||||||
/** @var AbstractProvider $providerClient */
|
/** @var AbstractProvider $providerClient */
|
||||||
$providerClient = $this->locator->get($provider->getConnectorProvider());
|
$providerClient = $this->locator->get($provider->getConnectorProvider());
|
||||||
$authData = $providerClient->verifyAuthData($connector->getAuthData());
|
$authData = $providerClient->verifyAuthData($connector->getAuthData());
|
||||||
$connector->setAuthData($authData);
|
|
||||||
$providerClient->authenticate($authData);
|
$connector->setAuthData($authData);
|
||||||
|
|
||||||
|
try {
|
||||||
|
$providerClient->authenticate($authData);
|
||||||
|
} catch (\Throwable $exception) {
|
||||||
|
$filesystem->remove($directory);
|
||||||
|
throw $exception;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
/** @var AbstractProvider $providerClient */
|
||||||
|
$providerClient = $this->locator->get($provider->getConnectorProvider());
|
||||||
|
$authData = $providerClient->verifyAuthData($connector->getAuthData());
|
||||||
|
$connector->setAuthData($authData);
|
||||||
|
|
||||||
|
$providerClient->authenticate($authData);
|
||||||
|
}
|
||||||
|
|
||||||
$this->logger->info('User {username} authentication data with the {provider} provider has been validated.', [
|
$this->logger->info('User {username} authentication data with the {provider} provider has been validated.', [
|
||||||
'username' => $user->getUserIdentifier(),
|
'username' => $user->getUserIdentifier(),
|
||||||
@@ -118,4 +134,36 @@ class ConnectorController extends AbstractController
|
|||||||
|
|
||||||
return $connector;
|
return $connector;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @throws \Exception
|
||||||
|
*/
|
||||||
|
#[Route(
|
||||||
|
path: '/api/connectors/{id}',
|
||||||
|
name: 'connector_delete',
|
||||||
|
defaults: [
|
||||||
|
'_api_resource_class' => Connector::class,
|
||||||
|
'_api_operation_name' => 'delete',
|
||||||
|
],
|
||||||
|
methods: ['DELETE']
|
||||||
|
)]
|
||||||
|
public function deleteConnector(Connector $connector): void
|
||||||
|
{
|
||||||
|
foreach ($connector->getWatchLists()->getIterator() as $watchlist) {
|
||||||
|
$watchlist->setConnector(null);
|
||||||
|
}
|
||||||
|
|
||||||
|
$provider = $connector->getProvider();
|
||||||
|
|
||||||
|
if (null === $provider) {
|
||||||
|
throw new BadRequestHttpException('Provider not found');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ConnectorProvider::EPP === $provider) {
|
||||||
|
(new Filesystem())->remove(sprintf('%s/%s/', EppClientProvider::EPP_CERTIFICATES_PATH, $connector->getId()));
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->em->remove($connector);
|
||||||
|
$this->em->flush();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -34,7 +34,9 @@ use Symfony\Component\Uid\Uuid;
|
|||||||
name: 'create'
|
name: 'create'
|
||||||
),
|
),
|
||||||
new Delete(
|
new Delete(
|
||||||
security: 'object.user == user'
|
routeName: 'connector_delete',
|
||||||
|
security: 'object.user == user',
|
||||||
|
name: 'delete'
|
||||||
),
|
),
|
||||||
]
|
]
|
||||||
)]
|
)]
|
||||||
|
|||||||
@@ -17,6 +17,8 @@ use Psr\Cache\InvalidArgumentException;
|
|||||||
|
|
||||||
class EppClientProvider extends AbstractProvider implements CheckDomainProviderInterface
|
class EppClientProvider extends AbstractProvider implements CheckDomainProviderInterface
|
||||||
{
|
{
|
||||||
|
public const EPP_CERTIFICATES_PATH = '../var/epp-certificates/';
|
||||||
|
|
||||||
private eppConnection $eppClient;
|
private eppConnection $eppClient;
|
||||||
|
|
||||||
public function __construct(
|
public function __construct(
|
||||||
|
|||||||
Reference in New Issue
Block a user