sender = new Address($mailerSenderEmail, $mailerSenderName); } /** * @throws TransportExceptionInterface * @throws \Exception */ public function __invoke(SendDomainEventNotif $message): void { /** @var WatchList $watchList */ $watchList = $this->watchListRepository->findOneBy(['token' => $message->watchListToken]); /** @var Domain $domain */ $domain = $this->domainRepository->findOneBy(['ldhName' => $message->ldhName]); $recipient = new Recipient($watchList->getUser()->getEmail()); /* * For each new event whose date is after the domain name update date (before the current domain name update) */ /** @var DomainEvent[] $newEvents */ $newEvents = $this->domainEventRepository->findNewDomainEvents($domain, $message->updatedAt); foreach ($newEvents as $event) { if (!in_array($event->getAction(), $watchList->getTrackedEvents())) { continue; } $notification = new DomainUpdateNotification($this->sender, $event); $this->logger->info('New action has been detected on this domain name : an email is sent to user', [ 'event' => $event->getAction(), 'ldhName' => $message->ldhName, 'username' => $watchList->getUser()->getUserIdentifier(), ]); $this->mailer->send($notification->asEmailMessage($recipient)->getMessage()); if ($this->influxdbEnabled) { $this->influxdbService->addDomainNotificationPoint($domain, 'email', true); } $webhookDsn = $watchList->getWebhookDsn(); if (null !== $webhookDsn && 0 !== count($webhookDsn)) { $this->logger->info('New action has been detected on this domain name : a notification is sent to user', [ 'event' => $event->getAction(), 'ldhName' => $message->ldhName, 'username' => $watchList->getUser()->getUserIdentifier(), ]); $this->chatNotificationService->sendChatNotification($watchList, $notification); if ($this->influxdbEnabled) { $this->influxdbService->addDomainNotificationPoint($domain, 'chat', true); } } $this->statService->incrementStat('stats.alert.sent'); } /** @var DomainStatus $domainStatus */ $domainStatus = $this->domainStatusRepository->findNewDomainStatus($domain, $message->updatedAt); if (null !== $domainStatus && count(array_intersect( $watchList->getTrackedEppStatus(), [...$domainStatus->getAddStatus(), ...$domainStatus->getDeleteStatus()] ))) { $notification = new DomainStatusUpdateNotification($this->sender, $domain, $domainStatus); $this->logger->info('New domain status has been detected on this domain name : an email is sent to user', [ 'addStatus' => $domainStatus->getAddStatus(), 'deleteStatus' => $domainStatus->getDeleteStatus(), 'status' => $domain->getStatus(), 'ldhName' => $message->ldhName, 'username' => $watchList->getUser()->getUserIdentifier(), ]); $this->mailer->send($notification->asEmailMessage($recipient)->getMessage()); if ($this->influxdbEnabled) { $this->influxdbService->addDomainNotificationPoint($domain, 'email', true); } $webhookDsn = $watchList->getWebhookDsn(); if (null !== $webhookDsn && 0 !== count($webhookDsn)) { $this->logger->info('New domain status has been detected on this domain name : a notification is sent to user', [ 'addStatus' => $domainStatus->getAddStatus(), 'deleteStatus' => $domainStatus->getDeleteStatus(), 'status' => $domain->getStatus(), 'ldhName' => $message->ldhName, 'username' => $watchList->getUser()->getUserIdentifier(), ]); $this->chatNotificationService->sendChatNotification($watchList, $notification); if ($this->influxdbEnabled) { $this->influxdbService->addDomainNotificationPoint($domain, 'chat', true); } } $this->statService->incrementStat('stats.alert.sent'); } } }