domain-watchdog/src/MessageHandler/ProcessDomainTriggerHandler.php

153 lines
5.9 KiB
PHP
Raw Normal View History

<?php
namespace App\MessageHandler;
2024-07-29 15:28:05 +02:00
use App\Config\Connector\OvhConnector;
use App\Config\ConnectorProvider;
use App\Config\TriggerAction;
2024-07-29 16:54:31 +02:00
use App\Entity\Connector;
use App\Entity\Domain;
use App\Entity\DomainEvent;
use App\Entity\User;
use App\Entity\WatchList;
use App\Entity\WatchListTrigger;
use App\Message\ProcessDomainTrigger;
use App\Repository\DomainRepository;
use App\Repository\WatchListRepository;
2024-08-04 14:45:27 +02:00
use Psr\Log\LoggerInterface;
use Symfony\Bridge\Twig\Mime\TemplatedEmail;
2024-07-29 15:28:05 +02:00
use Symfony\Component\HttpKernel\KernelInterface;
use Symfony\Component\Mailer\Exception\TransportExceptionInterface;
use Symfony\Component\Mailer\MailerInterface;
use Symfony\Component\Messenger\Attribute\AsMessageHandler;
2024-08-05 01:30:27 +02:00
use Symfony\Component\Mime\Address;
use Symfony\Component\Mime\Email;
#[AsMessageHandler]
final readonly class ProcessDomainTriggerHandler
{
public function __construct(
2024-08-02 23:24:52 +02:00
private string $mailerSenderEmail,
2024-08-05 01:30:27 +02:00
private string $mailerSenderName,
2024-08-02 23:24:52 +02:00
private MailerInterface $mailer,
private WatchListRepository $watchListRepository,
2024-08-02 23:24:52 +02:00
private DomainRepository $domainRepository,
2024-08-04 14:45:27 +02:00
private KernelInterface $kernel,
private LoggerInterface $logger
2024-08-02 23:24:52 +02:00
) {
}
/**
* @throws TransportExceptionInterface
2024-08-02 23:24:52 +02:00
* @throws \Exception
*/
public function __invoke(ProcessDomainTrigger $message): void
{
/** @var WatchList $watchList */
2024-08-02 23:24:52 +02:00
$watchList = $this->watchListRepository->findOneBy(['token' => $message->watchListToken]);
/** @var Domain $domain */
2024-08-02 23:24:52 +02:00
$domain = $this->domainRepository->findOneBy(['ldhName' => $message->ldhName]);
2024-07-30 21:34:48 +02:00
$connector = $watchList->getConnector();
if (null !== $connector && $domain->getDeleted()) {
2024-08-04 14:45:27 +02:00
$this->logger->notice('Watchlist {watchlist} is linked to connector {connector}. A purchase attempt will be made for domain name {ldhName} with provider {provider}.', [
'watchlist' => $message->watchListToken,
'connector' => $connector->getId(),
'ldhName' => $message->ldhName,
'provider' => $connector->getProvider()->value,
]);
2024-07-30 21:34:48 +02:00
try {
2024-08-02 23:24:52 +02:00
if (ConnectorProvider::OVH === $connector->getProvider()) {
$ovh = new OvhConnector($connector->getAuthData());
2024-07-30 21:34:48 +02:00
$isDebug = $this->kernel->isDebug();
2024-07-29 16:10:34 +02:00
2024-07-30 21:34:48 +02:00
$ovh->orderDomain($domain, $isDebug);
$this->sendEmailDomainOrdered($domain, $connector, $watchList->getUser());
2024-08-02 23:24:52 +02:00
} else {
throw new \Exception('Unknown provider');
}
} catch (\Throwable) {
2024-08-04 14:45:27 +02:00
$this->logger->warning('Unable to complete purchase. An error message is sent to user {username}.', [
'username' => $watchList->getUser()->getUserIdentifier(),
]);
2024-07-30 21:34:48 +02:00
$this->sendEmailDomainOrderError($domain, $watchList->getUser());
2024-07-29 16:10:34 +02:00
}
2024-07-30 21:34:48 +02:00
}
/** @var DomainEvent $event */
foreach ($domain->getEvents()->filter(fn ($event) => $message->updatedAt < $event->getDate() && $event->getDate() < new \DateTime()) as $event) {
2024-07-30 21:34:48 +02:00
$watchListTriggers = $watchList->getWatchListTriggers()
2024-08-02 23:24:52 +02:00
->filter(fn ($trigger) => $trigger->getEvent() === $event->getAction());
2024-07-29 16:10:34 +02:00
2024-07-30 21:34:48 +02:00
/** @var WatchListTrigger $watchListTrigger */
foreach ($watchListTriggers->getIterator() as $watchListTrigger) {
2024-08-04 14:45:27 +02:00
$this->logger->info('Action {event} has been detected on the domain name {ldhName}. A notification is sent to user {username}.', [
'event' => $event->getAction(),
'ldhName' => $message->ldhName,
'username' => $watchList->getUser()->getUserIdentifier(),
]);
2024-08-02 23:24:52 +02:00
if (TriggerAction::SendEmail == $watchListTrigger->getAction()) {
2024-07-29 16:10:34 +02:00
$this->sendEmailDomainUpdated($event, $watchList->getUser());
}
}
}
}
2024-07-29 16:54:31 +02:00
/**
* @throws TransportExceptionInterface
*/
private function sendEmailDomainOrdered(Domain $domain, Connector $connector, User $user): void
{
$email = (new TemplatedEmail())
2024-08-05 01:30:27 +02:00
->from(new Address($this->mailerSenderEmail, $this->mailerSenderName))
2024-07-29 16:54:31 +02:00
->to($user->getEmail())
->priority(Email::PRIORITY_HIGHEST)
->subject('A domain name has been ordered')
->htmlTemplate('emails/success/domain_ordered.html.twig')
->locale('en')
->context([
2024-08-02 23:24:52 +02:00
'domain' => $domain,
'provider' => $connector->getProvider()->value,
2024-07-29 16:54:31 +02:00
]);
$this->mailer->send($email);
}
2024-07-29 20:29:12 +02:00
/**
* @throws TransportExceptionInterface
*/
private function sendEmailDomainOrderError(Domain $domain, User $user): void
{
$email = (new TemplatedEmail())
2024-08-05 01:30:27 +02:00
->from(new Address($this->mailerSenderEmail, $this->mailerSenderName))
2024-07-29 20:29:12 +02:00
->to($user->getEmail())
->subject('An error occurred while ordering a domain name')
->htmlTemplate('emails/errors/domain_order.html.twig')
->locale('en')
->context([
2024-08-02 23:24:52 +02:00
'domain' => $domain,
2024-07-29 20:29:12 +02:00
]);
$this->mailer->send($email);
}
/**
* @throws TransportExceptionInterface
*/
private function sendEmailDomainUpdated(DomainEvent $domainEvent, User $user): void
{
$email = (new TemplatedEmail())
2024-08-05 01:30:27 +02:00
->from(new Address($this->mailerSenderEmail, $this->mailerSenderName))
->to($user->getEmail())
->priority(Email::PRIORITY_HIGHEST)
->subject('A domain name has been changed')
2024-07-29 16:54:31 +02:00
->htmlTemplate('emails/success/domain_updated.html.twig')
->locale('en')
->context([
2024-08-02 23:24:52 +02:00
'event' => $domainEvent,
]);
$this->mailer->send($email);
}
}