| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218 | <?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;use Symfony\Component\HttpFoundation\Session\SessionBagInterface;/** * MockArraySessionStorage mocks the session for unit tests. * * No PHP session is actually started since a session can be initialized * and shutdown only once per PHP execution cycle. * * When doing functional testing, you should use MockFileSessionStorage instead. * * @author Fabien Potencier <fabien@symfony.com> * @author Bulat Shakirzyanov <mallluhuct@gmail.com> * @author Drak <drak@zikula.org> */class MockArraySessionStorage implements SessionStorageInterface{    /**     * @var string     */    protected $id = '';    /**     * @var string     */    protected $name;    /**     * @var boolean     */    protected $started = false;    /**     * @var boolean     */    protected $closed = false;    /**     * @var array     */    protected $data = array();    /**     * Constructor.     *     * @param string $name Session name     */    public function __construct($name = 'MOCKSESSID')    {        $this->name = $name;    }    /**     * Sets the session data.     *     * @param array $array     */    public function setSessionData(array $array)    {        $this->data = $array;    }    /**     * {@inheritdoc}     */    public function start()    {        if ($this->started && !$this->closed) {            return true;        }        if (empty($this->id)) {            $this->id = $this->generateId();        }        $this->loadSession();        return true;    }    /**     * {@inheritdoc}     */    public function regenerate($destroy = false)    {        if (!$this->started) {            $this->start();        }        $this->id = $this->generateId();        return true;    }    /**     * {@inheritdoc}     */    public function getId()    {        return $this->id;    }    /**     * {@inheritdoc}     */    public function setId($id)    {        if ($this->started) {            throw new \LogicException('Cannot set session ID after the session has started.');        }        $this->id = $id;    }    /**     * {@inheritdoc}     */    public function getName()    {        return $this->name;    }    /**     * {@inheritdoc}     */    public function setName($name)    {        $this->name = $name;    }    /**     * {@inheritdoc}     */    public function save()    {        // nothing to do since we don't persist the session data        $this->closed = false;    }    /**     * {@inheritdoc}     */    public function clear()    {        // clear out the bags        foreach ($this->bags as $bag) {            $bag->clear();        }        // clear out the session        $this->data = array();        // reconnect the bags to the session        $this->loadSession();    }    /**     * {@inheritdoc}     */    public function registerBag(SessionBagInterface $bag)    {        $this->bags[$bag->getName()] = $bag;    }    /**     * {@inheritdoc}     */    public function getBag($name)    {        if (!isset($this->bags[$name])) {            throw new \InvalidArgumentException(sprintf('The SessionBagInterface %s is not registered.', $name));        }        if (!$this->started) {            $this->start();        }        return $this->bags[$name];    }    /**     * Generates a session ID.     *     * This doesn't need to be particularly cryptographically secure since this is just     * a mock.     *     * @return string     */    protected function generateId()    {        return sha1(uniqid(mt_rand()));    }    protected function loadSession()    {        foreach ($this->bags as $bag) {            $key = $bag->getStorageKey();            $this->data[$key] = isset($this->data[$key]) ? $this->data[$key] : array();            $bag->initialize($this->data[$key]);        }        $this->started = true;        $this->closed = false;    }}
 |