123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118 |
- <?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);
- }
- }
|