- <?php
- 
- /*
-  * This file is part of the Symfony package.
-  *
-  * (c) Fabien Potencier <fabien@symfony.com>
-  *
-  * For the full copyright and license information, please view the LICENSE
-  * file that was distributed with this source code.
-  */
- 
- namespace Symfony\Component\HttpKernel\EventListener;
- 
- use Psr\Container\ContainerInterface;
- use Symfony\Component\HttpFoundation\Session\SessionInterface;
- use Symfony\Component\HttpFoundation\Session\Storage\NativeSessionStorage;
- use Symfony\Component\HttpKernel\Event\GetResponseEvent;
- 
- /**
-  * Sets the session in the request.
-  *
-  * When the passed container contains a "session_storage" entry which
-  * holds a NativeSessionStorage instance, the "cookie_secure" option
-  * will be set to true whenever the current master request is secure.
-  *
-  * @author Fabien Potencier <fabien@symfony.com>
-  *
-  * @final
-  */
- class SessionListener extends AbstractSessionListener
- {
-     public function __construct(ContainerInterface $container)
-     {
-         $this->container = $container;
-     }
- 
-     public function onKernelRequest(GetResponseEvent $event)
-     {
-         parent::onKernelRequest($event);
- 
-         if (!$event->isMasterRequest() || !$this->container->has('session')) {
-             return;
-         }
- 
-         if ($this->container->has('session_storage')
-             && ($storage = $this->container->get('session_storage')) instanceof NativeSessionStorage
-             && ($masterRequest = $this->container->get('request_stack')->getMasterRequest())
-             && $masterRequest->isSecure()
-         ) {
-             $storage->setOptions(['cookie_secure' => true]);
-         }
-     }
- 
-     protected function getSession(): ?SessionInterface
-     {
-         if (!$this->container->has('session')) {
-             return null;
-         }
- 
-         return $this->container->get('session');
-     }
- }
-