![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/corals/mautic.corals.io/app/bundles/UserBundle/EventListener/ |
<?php namespace Mautic\UserBundle\EventListener; use Mautic\CoreBundle\Helper\CoreParametersHelper; use Symfony\Component\EventDispatcher\EventSubscriberInterface; use Symfony\Component\HttpFoundation\RedirectResponse; use Symfony\Component\HttpKernel\Event\RequestEvent; use Symfony\Component\HttpKernel\KernelEvents; use Symfony\Component\Routing\RouterInterface; class SAMLSubscriber implements EventSubscriberInterface { public function __construct( private CoreParametersHelper $coreParametersHelper, private RouterInterface $router ) { } public static function getSubscribedEvents(): array { return [ KernelEvents::REQUEST => ['onKernelRequest', 256], ]; } /** * Block access to SAML URLs if SAML is disabled. */ public function onKernelRequest(RequestEvent $event): void { if (!$event->isMainRequest()) { return; } $request = $event->getRequest(); $route = (string) $request->attributes->get('_route'); $url = (string) $request->getRequestUri(); if (!str_contains($route, 'lightsaml') && !str_contains($url, '/saml/')) { return; } $samlEnabled = (bool) $this->coreParametersHelper->get('saml_idp_metadata'); if ($samlEnabled) { return; } // Redirect to standard login page if SAML is disabled $event->setResponse( new RedirectResponse($this->router->generate('login')) ); } }