Files
@ a45f0dabc59c
Branch filter:
Location: hot67beta/libraries/joomla/session/storage.php
a45f0dabc59c
4.2 KiB
text/x-php
mneh
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 | <?php
/**
* @version $Id:sessionstorage.php 6961 2007-03-15 16:06:53Z tcp $
* @package Joomla.Framework
* @subpackage Session
* @copyright Copyright (C) 2005 - 2008 Open Source Matters. All rights reserved.
* @license GNU/GPL, see LICENSE.php
* Joomla! is free software. This version may have been modified pursuant
* to the GNU General Public License, and as distributed it includes or
* is derivative of works licensed under the GNU General Public License or
* other free or open source software licenses.
* See COPYRIGHT.php for copyright notices and details.
*/
// Check to ensure this file is within the rest of the framework
defined('JPATH_BASE') or die();
/**
* Custom session storage handler for PHP
*
* @abstract
* @package Joomla.Framework
* @subpackage Session
* @since 1.5
* @see http://www.php.net/manual/en/function.session-set-save-handler.php
*/
class JSessionStorage extends JObject
{
/**
* Constructor
*
* @access protected
* @param array $options optional parameters
*/
function __construct( $options = array() )
{
$this->register($options);
}
/**
* Returns a reference to a session storage handler object, only creating it
* if it doesn't already exist.
*
* @access public
* @param name $name The session store to instantiate
* @return database A JSessionStorage object
* @since 1.5
*/
function &getInstance($name = 'none', $options = array())
{
static $instances;
if (!isset ($instances)) {
$instances = array ();
}
$name = strtolower(JFilterInput::clean($name, 'word'));
if (empty ($instances[$name]))
{
$class = 'JSessionStorage'.ucfirst($name);
if(!class_exists($class))
{
$path = dirname(__FILE__).DS.'storage'.DS.$name.'.php';
if (file_exists($path)) {
require_once($path);
} else {
// No call to JError::raiseError here, as it tries to close the non-existing session
jexit('Unable to load session storage class: '.$name);
}
}
$instances[$name] = new $class($options);
}
return $instances[$name];
}
/**
* Register the functions of this class with PHP's session handler
*
* @access public
* @param array $options optional parameters
*/
function register( $options = array() )
{
// use this object as the session handler
session_set_save_handler(
array($this, 'open'),
array($this, 'close'),
array($this, 'read'),
array($this, 'write'),
array($this, 'destroy'),
array($this, 'gc')
);
}
/**
* Open the SessionHandler backend.
*
* @abstract
* @access public
* @param string $save_path The path to the session object.
* @param string $session_name The name of the session.
* @return boolean True on success, false otherwise.
*/
function open($save_path, $session_name)
{
return true;
}
/**
* Close the SessionHandler backend.
*
* @abstract
* @access public
* @return boolean True on success, false otherwise.
*/
function close()
{
return true;
}
/**
* Read the data for a particular session identifier from the
* SessionHandler backend.
*
* @abstract
* @access public
* @param string $id The session identifier.
* @return string The session data.
*/
function read($id)
{
return;
}
/**
* Write session data to the SessionHandler backend.
*
* @abstract
* @access public
* @param string $id The session identifier.
* @param string $session_data The session data.
* @return boolean True on success, false otherwise.
*/
function write($id, $session_data)
{
return true;
}
/**
* Destroy the data for a particular session identifier in the
* SessionHandler backend.
*
* @abstract
* @access public
* @param string $id The session identifier.
* @return boolean True on success, false otherwise.
*/
function destroy($id)
{
return true;
}
/**
* Garbage collect stale sessions from the SessionHandler backend.
*
* @abstract
* @access public
* @param integer $maxlifetime The maximum age of a session.
* @return boolean True on success, false otherwise.
*/
function gc($maxlifetime)
{
return true;
}
/**
* Test to see if the SessionHandler is available.
*
* @abstract
* @static
* @access public
* @return boolean True on success, false otherwise.
*/
function test()
{
return true;
}
}
|