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.
119 lines
2.7 KiB
119 lines
2.7 KiB
2 months ago
|
<?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);
|
||
|
}
|
||
|
}
|