New upstream version 0.6.27
This commit is contained in:
@@ -1,4 +1,12 @@
|
||||
<?php defined('SYSPATH') OR die('No direct access allowed.');
|
||||
<?php
|
||||
|
||||
// phpcs:disable PSR1.Classes.ClassDeclaration.MissingNamespace
|
||||
// phpcs:disable PSR1.Files.SideEffects
|
||||
defined('SYSPATH') or die('No direct access allowed.');
|
||||
// phpcs:enable PSR1.Files.SideEffects
|
||||
// phpcs:disable Squiz.Classes.ValidClassName.NotCamelCaps
|
||||
|
||||
|
||||
/**
|
||||
* Session cache driver.
|
||||
*
|
||||
@@ -17,89 +25,85 @@
|
||||
* @copyright (c) 2007-2008 Kohana Team
|
||||
* @license http://kohanaphp.com/license.html
|
||||
*/
|
||||
class Session_Cache_Driver implements Session_Driver {
|
||||
class Session_Cache_Driver implements Session_Driver
|
||||
{
|
||||
protected $cache;
|
||||
protected $encrypt;
|
||||
|
||||
protected $cache;
|
||||
protected $encrypt;
|
||||
public function __construct()
|
||||
{
|
||||
// Load Encrypt library
|
||||
if (Kohana::config('session.encryption')) {
|
||||
$this->encrypt = new Encrypt();
|
||||
}
|
||||
|
||||
public function __construct()
|
||||
{
|
||||
// Load Encrypt library
|
||||
if (Kohana::config('session.encryption'))
|
||||
{
|
||||
$this->encrypt = new Encrypt;
|
||||
}
|
||||
Kohana::log('debug', 'Session Cache Driver Initialized');
|
||||
}
|
||||
|
||||
Kohana::log('debug', 'Session Cache Driver Initialized');
|
||||
}
|
||||
public function open($path, $name)
|
||||
{
|
||||
$config = Kohana::config('session.storage');
|
||||
|
||||
public function open($path, $name)
|
||||
{
|
||||
$config = Kohana::config('session.storage');
|
||||
if (empty($config)) {
|
||||
// Load the default group
|
||||
$config = Kohana::config('cache.default');
|
||||
} elseif (is_string($config)) {
|
||||
$name = $config;
|
||||
|
||||
if (empty($config))
|
||||
{
|
||||
// Load the default group
|
||||
$config = Kohana::config('cache.default');
|
||||
}
|
||||
elseif (is_string($config))
|
||||
{
|
||||
$name = $config;
|
||||
// Test the config group name
|
||||
if (($config = Kohana::config('cache.' . $config)) === null) {
|
||||
throw new Kohana_Exception('cache.undefined_group', $name);
|
||||
}
|
||||
}
|
||||
|
||||
// Test the config group name
|
||||
if (($config = Kohana::config('cache.'.$config)) === NULL)
|
||||
throw new Kohana_Exception('cache.undefined_group', $name);
|
||||
}
|
||||
$config['lifetime'] = (Kohana::config('session.expiration') == 0) ? 86400 : Kohana::config('session.expiration');
|
||||
$this->cache = new Cache($config);
|
||||
|
||||
$config['lifetime'] = (Kohana::config('session.expiration') == 0) ? 86400 : Kohana::config('session.expiration');
|
||||
$this->cache = new Cache($config);
|
||||
return is_object($this->cache);
|
||||
}
|
||||
|
||||
return is_object($this->cache);
|
||||
}
|
||||
public function close()
|
||||
{
|
||||
return true;
|
||||
}
|
||||
|
||||
public function close()
|
||||
{
|
||||
return TRUE;
|
||||
}
|
||||
public function read($id)
|
||||
{
|
||||
$id = 'session_' . $id;
|
||||
if ($data = $this->cache->get($id)) {
|
||||
return Kohana::config('session.encryption') ? $this->encrypt->decode($data) : $data;
|
||||
}
|
||||
|
||||
public function read($id)
|
||||
{
|
||||
$id = 'session_'.$id;
|
||||
if ($data = $this->cache->get($id))
|
||||
{
|
||||
return Kohana::config('session.encryption') ? $this->encrypt->decode($data) : $data;
|
||||
}
|
||||
// Return value must be string, NOT a boolean
|
||||
return '';
|
||||
}
|
||||
|
||||
// Return value must be string, NOT a boolean
|
||||
return '';
|
||||
}
|
||||
public function write($id, $data)
|
||||
{
|
||||
$id = 'session_' . $id;
|
||||
$data = Kohana::config('session.encryption') ? $this->encrypt->encode($data) : $data;
|
||||
|
||||
public function write($id, $data)
|
||||
{
|
||||
$id = 'session_'.$id;
|
||||
$data = Kohana::config('session.encryption') ? $this->encrypt->encode($data) : $data;
|
||||
return $this->cache->set($id, $data);
|
||||
}
|
||||
|
||||
return $this->cache->set($id, $data);
|
||||
}
|
||||
public function destroy($id)
|
||||
{
|
||||
$id = 'session_' . $id;
|
||||
return $this->cache->delete($id);
|
||||
}
|
||||
|
||||
public function destroy($id)
|
||||
{
|
||||
$id = 'session_'.$id;
|
||||
return $this->cache->delete($id);
|
||||
}
|
||||
public function regenerate()
|
||||
{
|
||||
session_regenerate_id(true);
|
||||
|
||||
public function regenerate()
|
||||
{
|
||||
session_regenerate_id(TRUE);
|
||||
// Return new session id
|
||||
return session_id();
|
||||
}
|
||||
|
||||
// Return new session id
|
||||
return session_id();
|
||||
}
|
||||
|
||||
public function gc($maxlifetime)
|
||||
{
|
||||
// Just return, caches are automatically cleaned up
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
} // End Session Cache Driver
|
||||
public function gc($maxlifetime)
|
||||
{
|
||||
// Just return, caches are automatically cleaned up
|
||||
return true;
|
||||
}
|
||||
}
|
||||
// End Session Cache Driver
|
||||
|
||||
Reference in New Issue
Block a user