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.
110 lines
2.5 KiB
110 lines
2.5 KiB
11 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\Proxy;
|
||
|
|
||
|
/**
|
||
|
* @author Drak <drak@zikula.org>
|
||
|
*/
|
||
|
class SessionHandlerProxy extends AbstractProxy implements \SessionHandlerInterface, \SessionUpdateTimestampHandlerInterface
|
||
|
{
|
||
|
protected $handler;
|
||
|
|
||
|
public function __construct(\SessionHandlerInterface $handler)
|
||
|
{
|
||
|
$this->handler = $handler;
|
||
|
$this->wrapper = $handler instanceof \SessionHandler;
|
||
|
$this->saveHandlerName = $this->wrapper ? ini_get('session.save_handler') : 'user';
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @return \SessionHandlerInterface
|
||
|
*/
|
||
|
public function getHandler()
|
||
|
{
|
||
|
return $this->handler;
|
||
|
}
|
||
|
|
||
|
// \SessionHandlerInterface
|
||
|
|
||
|
/**
|
||
|
* @return bool
|
||
|
*/
|
||
|
#[\ReturnTypeWillChange]
|
||
|
public function open($savePath, $sessionName)
|
||
|
{
|
||
|
return $this->handler->open($savePath, $sessionName);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @return bool
|
||
|
*/
|
||
|
#[\ReturnTypeWillChange]
|
||
|
public function close()
|
||
|
{
|
||
|
return $this->handler->close();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @return string|false
|
||
|
*/
|
||
|
#[\ReturnTypeWillChange]
|
||
|
public function read($sessionId)
|
||
|
{
|
||
|
return $this->handler->read($sessionId);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @return bool
|
||
|
*/
|
||
|
#[\ReturnTypeWillChange]
|
||
|
public function write($sessionId, $data)
|
||
|
{
|
||
|
return $this->handler->write($sessionId, $data);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @return bool
|
||
|
*/
|
||
|
#[\ReturnTypeWillChange]
|
||
|
public function destroy($sessionId)
|
||
|
{
|
||
|
return $this->handler->destroy($sessionId);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @return int|false
|
||
|
*/
|
||
|
#[\ReturnTypeWillChange]
|
||
|
public function gc($maxlifetime)
|
||
|
{
|
||
|
return $this->handler->gc($maxlifetime);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @return bool
|
||
|
*/
|
||
|
#[\ReturnTypeWillChange]
|
||
|
public function validateId($sessionId)
|
||
|
{
|
||
|
return !$this->handler instanceof \SessionUpdateTimestampHandlerInterface || $this->handler->validateId($sessionId);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @return bool
|
||
|
*/
|
||
|
#[\ReturnTypeWillChange]
|
||
|
public function updateTimestamp($sessionId, $data)
|
||
|
{
|
||
|
return $this->handler instanceof \SessionUpdateTimestampHandlerInterface ? $this->handler->updateTimestamp($sessionId, $data) : $this->write($sessionId, $data);
|
||
|
}
|
||
|
}
|