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