vendor/symfony/mailer/EventListener/MessengerTransportListener.php line 26

  1. <?php
  2. /*
  3.  * This file is part of the Symfony package.
  4.  *
  5.  * (c) Fabien Potencier <fabien@symfony.com>
  6.  *
  7.  * For the full copyright and license information, please view the LICENSE
  8.  * file that was distributed with this source code.
  9.  */
  10. namespace Symfony\Component\Mailer\EventListener;
  11. use Symfony\Component\EventDispatcher\EventSubscriberInterface;
  12. use Symfony\Component\Mailer\Event\MessageEvent;
  13. use Symfony\Component\Messenger\Stamp\TransportNamesStamp;
  14. use Symfony\Component\Mime\Message;
  15. /**
  16.  * Allows messages to be sent to specific Messenger transports via the "X-Bus-Transport" MIME header.
  17.  *
  18.  * @author Fabien Potencier <fabien@symfony.com>
  19.  */
  20. final class MessengerTransportListener implements EventSubscriberInterface
  21. {
  22.     public function onMessage(MessageEvent $event): void
  23.     {
  24.         if (!$event->isQueued()) {
  25.             return;
  26.         }
  27.         $message $event->getMessage();
  28.         if (!$message instanceof Message || !$message->getHeaders()->has('X-Bus-Transport')) {
  29.             return;
  30.         }
  31.         $names $message->getHeaders()->get('X-Bus-Transport')->getBody();
  32.         $names array_map('trim'explode(','$names));
  33.         $event->addStamp(new TransportNamesStamp($names));
  34.         $message->getHeaders()->remove('X-Bus-Transport');
  35.     }
  36.     public static function getSubscribedEvents(): array
  37.     {
  38.         return [
  39.             MessageEvent::class => 'onMessage',
  40.         ];
  41.     }
  42. }