class MigratingSessionHandler implements SessionHandlerInterface, SessionUpdateTimestampHandlerInterface
Migrating session handler for migrating from one handler to another. It reads from the current handler and writes both the current and new ones.
It ignores errors from the new handler.
public
|
|
__construct(SessionHandlerInterface $currentHandler, SessionHandlerInterface $writeOnlyHandler)
|
No description | |
public
|
|
close()
|
{@inheritdoc} | |
public
|
|
destroy($sessionId)
|
{@inheritdoc} | |
public
|
|
gc($maxlifetime)
|
{@inheritdoc} | |
public
|
|
open($savePath, $sessionName)
|
{@inheritdoc} | |
public
|
|
read($sessionId)
|
{@inheritdoc} | |
public
|
|
write($sessionId, $sessionData)
|
{@inheritdoc} | |
public
|
|
validateId($sessionId)
|
{@inheritdoc} | |
public
|
|
updateTimestamp($sessionId, $sessionData)
|
{@inheritdoc} |
__construct()public __construct(SessionHandlerInterface $currentHandler, SessionHandlerInterface $writeOnlyHandler)
SessionHandlerInterface |
$currentHandler |
|
SessionHandlerInterface |
$writeOnlyHandler |
close()public close()
{@inheritdoc}
destroy()public destroy($sessionId)
{@inheritdoc}
$sessionId |
gc()public gc($maxlifetime)
{@inheritdoc}
$maxlifetime |
open()public open($savePath, $sessionName)
{@inheritdoc}
$savePath |
||
$sessionName |
read()public read($sessionId)
{@inheritdoc}
$sessionId |
write()public write($sessionId, $sessionData)
{@inheritdoc}
$sessionId |
||
$sessionData |
validateId()public validateId($sessionId)
{@inheritdoc}
$sessionId |
updateTimestamp()public updateTimestamp($sessionId, $sessionData)
{@inheritdoc}
$sessionId |
||
$sessionData |
<?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;
/**
* Migrating session handler for migrating from one handler to another. It reads
* from the current handler and writes both the current and new ones.
*
* It ignores errors from the new handler.
*
* @author Ross Motley <ross.motley@amara.com>
* @author Oliver Radwell <oliver.radwell@amara.com>
*/
class MigratingSessionHandler implements \SessionHandlerInterface, \SessionUpdateTimestampHandlerInterface
{
private $currentHandler;
private $writeOnlyHandler;
public function __construct(\SessionHandlerInterface $currentHandler, \SessionHandlerInterface $writeOnlyHandler)
{
if (!$currentHandler instanceof \SessionUpdateTimestampHandlerInterface) {
$currentHandler = new StrictSessionHandler($currentHandler);
}
if (!$writeOnlyHandler instanceof \SessionUpdateTimestampHandlerInterface) {
$writeOnlyHandler = new StrictSessionHandler($writeOnlyHandler);
}
$this->currentHandler = $currentHandler;
$this->writeOnlyHandler = $writeOnlyHandler;
}
/**
* {@inheritdoc}
*/
public function close()
{
$result = $this->currentHandler->close();
$this->writeOnlyHandler->close();
return $result;
}
/**
* {@inheritdoc}
*/
public function destroy($sessionId)
{
$result = $this->currentHandler->destroy($sessionId);
$this->writeOnlyHandler->destroy($sessionId);
return $result;
}
/**
* {@inheritdoc}
*/
public function gc($maxlifetime)
{
$result = $this->currentHandler->gc($maxlifetime);
$this->writeOnlyHandler->gc($maxlifetime);
return $result;
}
/**
* {@inheritdoc}
*/
public function open($savePath, $sessionName)
{
$result = $this->currentHandler->open($savePath, $sessionName);
$this->writeOnlyHandler->open($savePath, $sessionName);
return $result;
}
/**
* {@inheritdoc}
*/
public function read($sessionId)
{
// No reading from new handler until switch-over
return $this->currentHandler->read($sessionId);
}
/**
* {@inheritdoc}
*/
public function write($sessionId, $sessionData)
{
$result = $this->currentHandler->write($sessionId, $sessionData);
$this->writeOnlyHandler->write($sessionId, $sessionData);
return $result;
}
/**
* {@inheritdoc}
*/
public function validateId($sessionId)
{
// No reading from new handler until switch-over
return $this->currentHandler->validateId($sessionId);
}
/**
* {@inheritdoc}
*/
public function updateTimestamp($sessionId, $sessionData)
{
$result = $this->currentHandler->updateTimestamp($sessionId, $sessionData);
$this->writeOnlyHandler->updateTimestamp($sessionId, $sessionData);
return $result;
}
}