2011-12-03 09:42:39 +00:00
|
|
|
<?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.
|
|
|
|
*/
|
|
|
|
|
2012-02-08 23:15:47 +00:00
|
|
|
namespace Symfony\Component\HttpFoundation\Session\Storage;
|
2011-12-03 09:42:39 +00:00
|
|
|
|
|
|
|
/**
|
2012-02-11 11:04:05 +00:00
|
|
|
* MockFileSessionStorage is used to mock sessions for
|
2011-12-03 09:42:39 +00:00
|
|
|
* functional testing when done in a single PHP process.
|
|
|
|
*
|
|
|
|
* No PHP session is actually started since a session can be initialized
|
2012-03-14 11:53:34 +00:00
|
|
|
* and shutdown only once per PHP execution cycle and this class does
|
|
|
|
* not pollute any session related globals, including session_*() functions
|
|
|
|
* or session.* PHP ini directives.
|
2011-12-03 09:42:39 +00:00
|
|
|
*
|
|
|
|
* @author Drak <drak@zikula.org>
|
|
|
|
*/
|
2012-02-11 11:04:05 +00:00
|
|
|
class MockFileSessionStorage extends MockArraySessionStorage
|
2011-12-03 09:42:39 +00:00
|
|
|
{
|
|
|
|
/**
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
private $savePath;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Constructor.
|
|
|
|
*
|
2012-02-22 18:05:55 +00:00
|
|
|
* @param string $savePath Path of directory to save session files.
|
2012-03-14 11:53:34 +00:00
|
|
|
* @param string $name Session name.
|
2011-12-03 09:42:39 +00:00
|
|
|
*/
|
2012-03-14 11:53:34 +00:00
|
|
|
public function __construct($savePath = null, $name = 'MOCKSESSID')
|
2011-12-03 09:42:39 +00:00
|
|
|
{
|
2011-12-24 10:36:18 +00:00
|
|
|
if (null === $savePath) {
|
2011-12-03 09:42:39 +00:00
|
|
|
$savePath = sys_get_temp_dir();
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!is_dir($savePath)) {
|
|
|
|
mkdir($savePath, 0777, true);
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->savePath = $savePath;
|
|
|
|
|
2012-03-14 11:53:34 +00:00
|
|
|
parent::__construct($name);
|
2011-12-03 09:42:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* {@inheritdoc}
|
|
|
|
*/
|
|
|
|
public function start()
|
|
|
|
{
|
|
|
|
if ($this->started) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2012-03-14 11:53:34 +00:00
|
|
|
if (!$this->id) {
|
|
|
|
$this->id = $this->generateId();
|
2011-12-03 09:42:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
$this->read();
|
|
|
|
|
|
|
|
$this->started = true;
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* {@inheritdoc}
|
|
|
|
*/
|
2012-03-30 18:02:35 +01:00
|
|
|
public function regenerate($destroy = false, $lifetime = null)
|
2011-12-03 09:42:39 +00:00
|
|
|
{
|
2012-03-29 12:30:37 +01:00
|
|
|
if (!$this->started) {
|
|
|
|
$this->start();
|
|
|
|
}
|
2012-03-30 18:02:35 +01:00
|
|
|
|
2011-12-03 09:42:39 +00:00
|
|
|
if ($destroy) {
|
|
|
|
$this->destroy();
|
|
|
|
}
|
|
|
|
|
2012-03-30 18:02:35 +01:00
|
|
|
return parent::regenerate($destroy, $lifetime);
|
2011-12-03 09:42:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* {@inheritdoc}
|
|
|
|
*/
|
2012-03-14 11:53:34 +00:00
|
|
|
public function save()
|
2011-12-03 09:42:39 +00:00
|
|
|
{
|
2012-03-14 11:53:34 +00:00
|
|
|
file_put_contents($this->getFilePath(), serialize($this->data));
|
2011-12-03 09:42:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2012-03-14 11:53:34 +00:00
|
|
|
* Deletes a session from persistent storage.
|
|
|
|
* Deliberately leaves session data in memory intact.
|
2011-12-03 09:42:39 +00:00
|
|
|
*/
|
|
|
|
private function destroy()
|
|
|
|
{
|
|
|
|
if (is_file($this->getFilePath())) {
|
|
|
|
unlink($this->getFilePath());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Calculate path to file.
|
|
|
|
*
|
|
|
|
* @return string File path
|
|
|
|
*/
|
2012-03-14 11:53:34 +00:00
|
|
|
private function getFilePath()
|
2011-12-03 09:42:39 +00:00
|
|
|
{
|
2012-03-14 11:53:34 +00:00
|
|
|
return $this->savePath.'/'.$this->id.'.mocksess';
|
2011-12-03 09:42:39 +00:00
|
|
|
}
|
|
|
|
|
2012-03-14 11:53:34 +00:00
|
|
|
/**
|
|
|
|
* Reads session from storage and loads session.
|
|
|
|
*/
|
2011-12-03 09:42:39 +00:00
|
|
|
private function read()
|
|
|
|
{
|
|
|
|
$filePath = $this->getFilePath();
|
2012-03-14 11:53:34 +00:00
|
|
|
$this->data = is_readable($filePath) && is_file($filePath) ? unserialize(file_get_contents($filePath)) : array();
|
2011-12-03 09:42:39 +00:00
|
|
|
|
2012-03-14 11:53:34 +00:00
|
|
|
$this->loadSession();
|
2011-12-03 09:42:39 +00:00
|
|
|
}
|
|
|
|
}
|