You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
118 lines
2.7 KiB
118 lines
2.7 KiB
<?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);
|
|
}
|
|
}
|
|
|