- <?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\HttpFoundation\Session\Storage\Handler;
- /**
-  * Adds basic `SessionUpdateTimestampHandlerInterface` behaviors to another `SessionHandlerInterface`.
-  *
-  * @author Nicolas Grekas <p@tchwork.com>
-  */
- class StrictSessionHandler extends AbstractSessionHandler
- {
-     private $handler;
-     private $doDestroy;
-     public function __construct(\SessionHandlerInterface $handler)
-     {
-         if ($handler instanceof \SessionUpdateTimestampHandlerInterface) {
-             throw new \LogicException(sprintf('"%s" is already an instance of "SessionUpdateTimestampHandlerInterface", you cannot wrap it with "%s".', get_debug_type($handler), self::class));
-         }
-         $this->handler = $handler;
-     }
-     /**
-      * Returns true if this handler wraps an internal PHP session save handler using \SessionHandler.
-      *
-      * @internal
-      */
-     public function isWrapper(): bool
-     {
-         return $this->handler instanceof \SessionHandler;
-     }
-     /**
-      * @return bool
-      */
-     #[\ReturnTypeWillChange]
-     public function open($savePath, $sessionName)
-     {
-         parent::open($savePath, $sessionName);
-         return $this->handler->open($savePath, $sessionName);
-     }
-     /**
-      * {@inheritdoc}
-      */
-     protected function doRead(string $sessionId)
-     {
-         return $this->handler->read($sessionId);
-     }
-     /**
-      * @return bool
-      */
-     #[\ReturnTypeWillChange]
-     public function updateTimestamp($sessionId, $data)
-     {
-         return $this->write($sessionId, $data);
-     }
-     /**
-      * {@inheritdoc}
-      */
-     protected function doWrite(string $sessionId, string $data)
-     {
-         return $this->handler->write($sessionId, $data);
-     }
-     /**
-      * @return bool
-      */
-     #[\ReturnTypeWillChange]
-     public function destroy($sessionId)
-     {
-         $this->doDestroy = true;
-         $destroyed = parent::destroy($sessionId);
-         return $this->doDestroy ? $this->doDestroy($sessionId) : $destroyed;
-     }
-     /**
-      * {@inheritdoc}
-      */
-     protected function doDestroy(string $sessionId)
-     {
-         $this->doDestroy = false;
-         return $this->handler->destroy($sessionId);
-     }
-     /**
-      * @return bool
-      */
-     #[\ReturnTypeWillChange]
-     public function close()
-     {
-         return $this->handler->close();
-     }
-     /**
-      * @return int|false
-      */
-     #[\ReturnTypeWillChange]
-     public function gc($maxlifetime)
-     {
-         return $this->handler->gc($maxlifetime);
-     }
- }
-