Files
@ 7ec91347b83f
Branch filter:
Location: hot67beta/libraries/joomla/session/storage/eaccelerator.php
7ec91347b83f
3.2 KiB
text/x-php
there we go
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 | <?php
/**
* @version $Id:eaccelerator.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();
/**
* eAccelerator session storage handler for PHP
*
* @package Joomla.Framework
* @subpackage Session
* @since 1.5
* @see http://www.php.net/manual/en/function.session-set-save-handler.php
*/
class JSessionStorageEaccelerator extends JSessionStorage
{
/**
* Constructor
*
* @access protected
* @param array $options optional parameters
*/
function __construct( $options = array() )
{
if (!$this->test()) {
return JError::raiseError(404, "The eaccelerator extension is not available");
}
parent::__construct($options);
}
/**
* Open the SessionHandler backend.
*
* @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.
*
* @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.
*
* @access public
* @param string $id The session identifier.
* @return string The session data.
*/
function read($id)
{
$sess_id = 'sess_'.$id;
return (string) eaccelerator_get($sess_id);
}
/**
* Write session data to the SessionHandler backend.
*
* @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)
{
$sess_id = 'sess_'.$id;
return eaccelerator_put($sess_id, $session_data, ini_get("session.gc_maxlifetime"));
}
/**
* Destroy the data for a particular session identifier in the
* SessionHandler backend.
*
* @access public
* @param string $id The session identifier.
* @return boolean True on success, false otherwise.
*/
function destroy($id)
{
$sess_id = 'sess_'.$id;
return eaccelerator_rm($sess_id);
}
/**
* Garbage collect stale sessions from the SessionHandler backend.
*
* @access public
* @param integer $maxlifetime The maximum age of a session.
* @return boolean True on success, false otherwise.
*/
function gc($maxlifetime)
{
eaccelerator_gc();
return true;
}
/**
* Test to see if the SessionHandler is available.
*
* @static
* @access public
* @return boolean True on success, false otherwise.
*/
function test() {
return (extension_loaded('eaccelerator') && function_exists('eaccelerator_get'));
}
}
|