2008-05-30 11:40:08 +00:00
< ? php
/**
* Session class for Cake .
*
* Cake abstracts the handling of sessions .
* There are several convenient methods to access session information .
* This class is the implementation of those methods .
* They are mostly used by the Session Component .
*
2010-10-03 12:38:58 -04:00
* PHP 5
2008-05-30 11:40:08 +00:00
*
2009-11-06 17:46:59 +11:00
* CakePHP ( tm ) : Rapid Development Framework ( http :// cakephp . org )
2011-05-29 17:31:39 -04:00
* Copyright 2005 - 2011 , Cake Software Foundation , Inc . ( http :// cakefoundation . org )
2008-05-30 11:40:08 +00:00
*
* Licensed under The MIT License
* Redistributions of files must retain the above copyright notice .
*
2011-05-29 17:31:39 -04:00
* @ copyright Copyright 2005 - 2011 , Cake Software Foundation , Inc . ( http :// cakefoundation . org )
2009-11-06 17:00:11 +11:00
* @ link http :// cakephp . org CakePHP ( tm ) Project
2011-07-26 01:46:14 -04:30
* @ package Cake . Model . Datasource
2008-10-30 17:30:26 +00:00
* @ since CakePHP ( tm ) v . 0.10 . 0.1222
2009-11-06 17:51:51 +11:00
* @ license MIT License ( http :// www . opensource . org / licenses / mit - license . php )
2008-05-30 11:40:08 +00:00
*/
2009-04-13 15:47:40 -04:00
2010-12-04 02:51:42 -04:30
App :: uses ( 'Set' , 'Utility' );
2010-12-15 01:13:05 -04:30
App :: uses ( 'Security' , 'Utility' );
2010-12-04 02:51:42 -04:30
2008-05-30 11:40:08 +00:00
/**
* Session class for Cake .
*
* Cake abstracts the handling of sessions . There are several convenient methods to access session information .
* This class is the implementation of those methods . They are mostly used by the Session Component .
*
2011-07-26 01:46:14 -04:30
* @ package Cake . Model . Datasource
2008-05-30 11:40:08 +00:00
*/
2010-07-04 20:06:24 +10:00
class CakeSession {
2009-07-24 21:18:37 +02:00
2008-05-30 11:40:08 +00:00
/**
* True if the Session is still valid
*
* @ var boolean
*/
2010-06-23 11:25:04 +10:00
public static $valid = false ;
2009-07-24 21:18:37 +02:00
2008-05-30 11:40:08 +00:00
/**
* Error messages for this session
*
* @ var array
*/
2010-06-23 11:25:04 +10:00
public static $error = false ;
2009-07-24 21:18:37 +02:00
2008-05-30 11:40:08 +00:00
/**
* User agent string
*
* @ var string
*/
2010-06-23 11:25:04 +10:00
protected static $_userAgent = '' ;
2009-07-24 21:18:37 +02:00
2008-05-30 11:40:08 +00:00
/**
* Path to where the session is active .
*
* @ var string
*/
2010-06-23 11:25:04 +10:00
public static $path = '/' ;
2009-07-24 21:18:37 +02:00
2008-05-30 11:40:08 +00:00
/**
* Error number of last occurred error
*
* @ var integer
*/
2010-06-23 11:25:04 +10:00
public static $lastError = null ;
2009-07-24 21:18:37 +02:00
2008-05-30 11:40:08 +00:00
/**
* 'Security.level' setting , " high " , " medium " , or " low " .
*
* @ var string
*/
2010-06-23 11:25:04 +10:00
public static $security = null ;
2009-07-24 21:18:37 +02:00
2008-05-30 11:40:08 +00:00
/**
* Start time for this session .
*
* @ var integer
*/
2010-06-23 11:25:04 +10:00
public static $time = false ;
2009-07-24 21:18:37 +02:00
2010-06-23 11:42:21 +10:00
/**
* Cookie lifetime
*
* @ var integer
*/
public static $cookieLifeTime ;
2008-05-30 11:40:08 +00:00
/**
* Time when this session becomes invalid .
*
* @ var integer
*/
2010-06-23 11:25:04 +10:00
public static $sessionTime = false ;
2009-07-24 21:18:37 +02:00
2008-05-30 11:40:08 +00:00
/**
* Current Session id
*
* @ var string
*/
2010-06-23 11:25:04 +10:00
public static $id = null ;
2009-07-24 21:18:37 +02:00
2010-03-26 22:51:58 +11:00
/**
* Hostname
*
* @ var string
*/
2010-06-23 11:25:04 +10:00
public static $host = null ;
2010-03-26 22:53:30 +11:00
2010-04-29 09:45:20 +10:00
/**
* Session timeout multiplier factor
*
2010-06-27 12:17:37 -04:00
* @ var integer
2010-04-29 09:45:20 +10:00
*/
2010-06-23 11:25:04 +10:00
public static $timeout = null ;
2010-04-29 09:45:20 +10:00
2010-07-25 17:50:08 -04:00
/**
* Number of requests that can occur during a session time without the session being renewed .
* This feature is only used when `Session.harden` is set to true .
*
* @ var integer
* @ see CakeSession :: _checkValid ()
*/
public static $requestCountdown = 10 ;
2008-05-30 11:40:08 +00:00
/**
* Constructor .
*
* @ param string $base The base path for the Session
* @ param boolean $start Should session be started right now
2011-07-30 18:38:57 -04:00
* @ return void
2008-05-30 11:40:08 +00:00
*/
2010-07-04 20:06:24 +10:00
public static function init ( $base = null , $start = true ) {
2010-06-23 11:25:04 +10:00
self :: $time = time ();
2008-05-30 11:40:08 +00:00
2010-07-04 20:06:24 +10:00
$checkAgent = Configure :: read ( 'Session.checkAgent' );
if (( $checkAgent === true || $checkAgent === null ) && env ( 'HTTP_USER_AGENT' ) != null ) {
self :: $_userAgent = md5 ( env ( 'HTTP_USER_AGENT' ) . Configure :: read ( 'Security.salt' ));
2008-05-30 11:40:08 +00:00
}
2010-12-09 23:41:07 -05:00
self :: _setPath ( $base );
self :: _setHost ( env ( 'HTTP_HOST' ));
2008-05-30 11:40:08 +00:00
}
2009-07-24 21:18:37 +02:00
2010-07-22 11:05:39 +10:00
/**
* Setup the Path variable
*
* @ param string $base base path
* @ return void
*/
protected static function _setPath ( $base = null ) {
if ( empty ( $base )) {
self :: $path = '/' ;
return ;
}
if ( strpos ( $base , 'index.php' ) !== false ) {
2010-07-22 18:42:56 +10:00
$base = str_replace ( 'index.php' , '' , $base );
2010-07-22 11:05:39 +10:00
}
if ( strpos ( $base , '?' ) !== false ) {
2010-07-22 18:42:56 +10:00
$base = str_replace ( '?' , '' , $base );
2010-07-22 11:05:39 +10:00
}
2010-07-22 18:42:56 +10:00
self :: $path = $base ;
2010-07-22 11:05:39 +10:00
}
/**
2010-07-22 19:09:48 +10:00
* Set the host name
2010-07-22 11:05:39 +10:00
*
2010-07-22 19:09:48 +10:00
* @ param string $host Hostname
2010-07-22 11:05:39 +10:00
* @ return void
*/
2010-07-22 19:09:48 +10:00
protected static function _setHost ( $host ) {
self :: $host = $host ;
2010-07-22 11:05:39 +10:00
if ( strpos ( self :: $host , ':' ) !== false ) {
self :: $host = substr ( self :: $host , 0 , strpos ( self :: $host , ':' ));
}
}
2008-05-30 11:40:08 +00:00
/**
* Starts the Session .
*
2010-03-26 10:46:48 +11:00
* @ return boolean True if session was started
2008-05-30 11:40:08 +00:00
*/
2010-06-23 11:25:04 +10:00
public static function start () {
2010-07-22 18:42:56 +10:00
if ( self :: started ()) {
return true ;
2010-03-26 10:46:48 +11:00
}
2010-07-26 00:32:31 -04:00
$id = self :: id ();
2010-07-22 18:42:56 +10:00
session_write_close ();
2010-07-25 01:14:41 -04:00
self :: _configureSession ();
2010-07-22 18:42:56 +10:00
self :: _startSession ();
2010-07-25 17:50:08 -04:00
2010-07-26 00:32:31 -04:00
if ( ! $id && self :: started ()) {
2010-07-22 18:42:56 +10:00
self :: _checkValid ();
2010-07-20 23:35:59 -04:00
}
2010-07-22 18:42:56 +10:00
2010-07-26 23:11:57 -04:00
self :: $error = false ;
2010-07-20 23:35:59 -04:00
return self :: started ();
}
2008-05-30 11:40:08 +00:00
/**
* Determine if Session has been started .
*
2008-09-25 16:49:56 +00:00
* @ return boolean True if session has been started .
2008-05-30 11:40:08 +00:00
*/
2010-06-23 11:25:04 +10:00
public static function started () {
2010-07-12 10:31:31 +10:00
return isset ( $_SESSION ) && session_id ();
2008-05-30 11:40:08 +00:00
}
2009-07-24 21:18:37 +02:00
2008-05-30 11:40:08 +00:00
/**
* Returns true if given variable is set in session .
*
* @ param string $name Variable name to check for
* @ return boolean True if variable is there
*/
2010-07-22 19:19:53 +10:00
public static function check ( $name = null ) {
2010-12-09 23:55:38 -05:00
if ( ! self :: started () && ! self :: start ()) {
return false ;
}
2009-11-21 20:44:35 -05:00
if ( empty ( $name )) {
2008-06-20 20:17:23 +00:00
return false ;
2008-05-30 11:40:08 +00:00
}
2009-11-21 20:44:35 -05:00
$result = Set :: classicExtract ( $_SESSION , $name );
2008-05-30 11:40:08 +00:00
return isset ( $result );
}
2009-07-24 21:18:37 +02:00
2008-05-30 11:40:08 +00:00
/**
2008-09-25 16:49:56 +00:00
* Returns the Session id
2008-09-26 14:03:16 +00:00
*
2011-07-30 18:38:57 -04:00
* @ param string $id
2008-05-30 11:40:08 +00:00
* @ return string Session id
*/
2010-06-23 11:25:04 +10:00
public static function id ( $id = null ) {
2008-05-30 11:40:08 +00:00
if ( $id ) {
2010-06-23 11:25:04 +10:00
self :: $id = $id ;
session_id ( self :: $id );
2008-05-30 11:40:08 +00:00
}
2010-06-23 11:25:04 +10:00
if ( self :: started ()) {
2008-05-30 11:40:08 +00:00
return session_id ();
}
2010-06-23 11:25:04 +10:00
return self :: $id ;
2008-05-30 11:40:08 +00:00
}
2009-07-24 21:18:37 +02:00
2008-05-30 11:40:08 +00:00
/**
* Removes a variable from session .
*
* @ param string $name Session variable to remove
* @ return boolean Success
*/
2010-06-23 11:25:04 +10:00
public static function delete ( $name ) {
if ( self :: check ( $name )) {
2011-08-20 00:43:34 -04:00
self :: _overwrite ( $_SESSION , Set :: remove ( $_SESSION , $name ));
2010-06-23 11:25:04 +10:00
return ( self :: check ( $name ) == false );
2008-05-30 11:40:08 +00:00
}
2011-08-20 00:43:34 -04:00
self :: _setError ( 2 , __d ( 'cake_dev' , " %s doesn't exist " , $name ));
2008-05-30 11:40:08 +00:00
return false ;
}
2009-07-24 21:18:37 +02:00
2008-05-30 11:40:08 +00:00
/**
* Used to write new data to _SESSION , since PHP doesn ' t like us setting the _SESSION var itself
*
* @ param array $old Set of old variables => values
* @ param array $new New set of variable => value
2011-07-30 18:38:57 -04:00
* @ return void
2008-05-30 11:40:08 +00:00
*/
2011-08-20 00:43:34 -04:00
protected static function _overwrite ( & $old , $new ) {
2008-10-23 00:10:44 +00:00
if ( ! empty ( $old )) {
2008-05-30 11:40:08 +00:00
foreach ( $old as $key => $var ) {
if ( ! isset ( $new [ $key ])) {
unset ( $old [ $key ]);
}
}
}
foreach ( $new as $key => $var ) {
$old [ $key ] = $var ;
}
}
2009-07-24 21:18:37 +02:00
2008-05-30 11:40:08 +00:00
/**
* Return error description for given error number .
*
* @ param integer $errorNumber Error to set
* @ return string Error as string
*/
2011-08-20 00:43:34 -04:00
protected static function _error ( $errorNumber ) {
2010-06-23 11:25:04 +10:00
if ( ! is_array ( self :: $error ) || ! array_key_exists ( $errorNumber , self :: $error )) {
2008-05-30 11:40:08 +00:00
return false ;
} else {
2010-06-23 11:25:04 +10:00
return self :: $error [ $errorNumber ];
2008-05-30 11:40:08 +00:00
}
}
2009-07-24 21:18:37 +02:00
2008-05-30 11:40:08 +00:00
/**
* Returns last occurred error as a string , if any .
*
* @ return mixed Error description as a string , or false .
*/
2010-06-23 11:25:04 +10:00
public static function error () {
if ( self :: $lastError ) {
2011-08-20 00:43:34 -04:00
return self :: _error ( self :: $lastError );
2008-05-30 11:40:08 +00:00
}
2010-06-23 11:25:04 +10:00
return false ;
2008-05-30 11:40:08 +00:00
}
2009-07-24 21:18:37 +02:00
2008-05-30 11:40:08 +00:00
/**
* Returns true if session is valid .
*
* @ return boolean Success
*/
2010-06-23 11:25:04 +10:00
public static function valid () {
if ( self :: read ( 'Config' )) {
2010-07-26 23:11:57 -04:00
if ( self :: _validAgentAndTime () && self :: $error === false ) {
2010-07-26 23:01:23 -04:00
self :: $valid = true ;
2008-05-30 11:40:08 +00:00
} else {
2010-06-23 11:25:04 +10:00
self :: $valid = false ;
2011-08-20 00:43:34 -04:00
self :: _setError ( 1 , 'Session Highjacking Attempted !!!' );
2008-05-30 11:40:08 +00:00
}
}
2010-06-23 11:25:04 +10:00
return self :: $valid ;
2008-05-30 11:40:08 +00:00
}
2009-07-24 21:18:37 +02:00
2010-07-26 23:01:23 -04:00
/**
* Tests that the user agent is valid and that the session hasn 't ' timed out ' .
* Since timeouts are implemented in CakeSession it checks the current self :: $time
2011-08-15 23:55:08 -04:00
* against the time the session is set to expire . The User agent is only checked
2010-07-26 23:01:23 -04:00
* if Session . checkAgent == true .
*
* @ return boolean
*/
protected static function _validAgentAndTime () {
2010-12-06 09:38:06 -04:30
$config = self :: read ( 'Config' );
2010-07-26 23:01:23 -04:00
$validAgent = (
Configure :: read ( 'Session.checkAgent' ) === false ||
2010-12-06 09:38:06 -04:30
self :: $_userAgent == $config [ 'userAgent' ]
2010-07-26 23:01:23 -04:00
);
2010-12-06 09:38:06 -04:30
return ( $validAgent && self :: $time <= $config [ 'time' ]);
2010-07-26 23:01:23 -04:00
}
2010-07-20 23:35:59 -04:00
/**
2010-07-26 23:11:57 -04:00
* Get / Set the userAgent
2010-07-20 23:35:59 -04:00
*
* @ param string $userAgent Set the userAgent
* @ return void
*/
public static function userAgent ( $userAgent = null ) {
if ( $userAgent ) {
self :: $_userAgent = $userAgent ;
}
return self :: $_userAgent ;
}
2008-05-30 11:40:08 +00:00
/**
* Returns given session variable , or all of them , if no parameters given .
*
* @ param mixed $name The name of the session variable ( or a path as sent to Set . extract )
* @ return mixed The value of the session variable
*/
2010-06-23 11:25:04 +10:00
public static function read ( $name = null ) {
2010-12-09 23:55:38 -05:00
if ( ! self :: started () && ! self :: start ()) {
2008-05-30 11:40:08 +00:00
return false ;
}
if ( is_null ( $name )) {
2011-08-20 00:43:34 -04:00
return self :: _returnSessionVars ();
2008-05-30 11:40:08 +00:00
}
if ( empty ( $name )) {
return false ;
}
2009-11-21 20:25:45 -05:00
$result = Set :: classicExtract ( $_SESSION , $name );
2008-05-30 11:40:08 +00:00
if ( ! is_null ( $result )) {
return $result ;
}
2011-08-20 00:43:34 -04:00
self :: _setError ( 2 , " $name doesn't exist " );
2008-05-30 11:40:08 +00:00
return null ;
}
2009-07-24 21:18:37 +02:00
2008-05-30 11:40:08 +00:00
/**
* Returns all session variables .
*
* @ return mixed Full $_SESSION array , or false on error .
*/
2011-08-20 00:43:34 -04:00
protected static function _returnSessionVars () {
2008-05-30 11:40:08 +00:00
if ( ! empty ( $_SESSION )) {
return $_SESSION ;
}
2011-08-20 00:43:34 -04:00
self :: _setError ( 2 , 'No Session vars set' );
2008-05-30 11:40:08 +00:00
return false ;
}
2009-07-24 21:18:37 +02:00
2008-05-30 11:40:08 +00:00
/**
* Writes value to given session variable name .
*
* @ param mixed $name Name of variable
* @ param string $value Value to write
* @ return boolean True if the write was successful , false if the write failed
*/
2010-07-15 23:54:01 -04:00
public static function write ( $name , $value = null ) {
2010-12-09 23:55:38 -05:00
if ( ! self :: started () && ! self :: start ()) {
return false ;
}
2009-11-21 20:44:35 -05:00
if ( empty ( $name )) {
2008-05-30 11:40:08 +00:00
return false ;
}
2010-07-15 23:54:01 -04:00
$write = $name ;
if ( ! is_array ( $name )) {
$write = array ( $name => $value );
2008-05-30 11:40:08 +00:00
}
2010-07-15 23:54:01 -04:00
foreach ( $write as $key => $val ) {
2011-08-20 00:43:34 -04:00
self :: _overwrite ( $_SESSION , Set :: insert ( $_SESSION , $key , $val ));
2010-07-15 23:54:01 -04:00
if ( Set :: classicExtract ( $_SESSION , $key ) !== $val ) {
return false ;
}
}
return true ;
2008-05-30 11:40:08 +00:00
}
2009-07-24 21:18:37 +02:00
2008-05-30 11:40:08 +00:00
/**
* Helper method to destroy invalid sessions .
*
2008-09-25 16:49:56 +00:00
* @ return void
2008-05-30 11:40:08 +00:00
*/
2010-07-12 09:57:04 +10:00
public static function destroy () {
2010-07-26 22:38:40 -04:00
if ( self :: started ()) {
session_destroy ();
}
2010-09-29 23:01:23 -04:00
self :: clear ();
}
/**
* Clears the session , the session id , and renew ' s the session .
*
* @ return void
*/
public static function clear () {
2010-07-25 19:55:02 -04:00
$_SESSION = null ;
2010-07-07 23:33:38 -04:00
self :: $id = null ;
2010-06-23 11:25:04 +10:00
self :: start ();
self :: renew ();
2008-05-30 11:40:08 +00:00
}
2009-07-24 21:18:37 +02:00
2008-05-30 11:40:08 +00:00
/**
* Helper method to initialize a session , based on Cake core settings .
*
2010-07-25 00:42:28 -04:00
* Sessions can be configured with a few shortcut names as well as have any number of ini settings declared .
*
2010-07-25 01:14:41 -04:00
* @ return void
2010-12-11 19:01:07 -05:00
* @ throws CakeSessionException Throws exceptions when ini_set () fails .
2008-05-30 11:40:08 +00:00
*/
2010-07-25 01:14:41 -04:00
protected static function _configureSession () {
2010-07-25 00:42:28 -04:00
$sessionConfig = Configure :: read ( 'Session' );
2008-10-23 00:10:44 +00:00
$iniSet = function_exists ( 'ini_set' );
2010-07-25 00:42:28 -04:00
if ( isset ( $sessionConfig [ 'defaults' ])) {
$defaults = self :: _defaultConfig ( $sessionConfig [ 'defaults' ]);
if ( $defaults ) {
$sessionConfig = Set :: merge ( $defaults , $sessionConfig );
}
}
if ( ! isset ( $sessionConfig [ 'ini' ][ 'session.cookie_secure' ]) && env ( 'HTTPS' )) {
$sessionConfig [ 'ini' ][ 'session.cookie_secure' ] = 1 ;
}
if ( isset ( $sessionConfig [ 'timeout' ]) && ! isset ( $sessionConfig [ 'cookieTimeout' ])) {
$sessionConfig [ 'cookieTimeout' ] = $sessionConfig [ 'timeout' ];
2008-08-12 23:47:00 +00:00
}
2010-07-25 00:42:28 -04:00
if ( ! isset ( $sessionConfig [ 'ini' ][ 'session.cookie_lifetime' ])) {
$sessionConfig [ 'ini' ][ 'session.cookie_lifetime' ] = $sessionConfig [ 'cookieTimeout' ] * 60 ;
}
if ( ! isset ( $sessionConfig [ 'ini' ][ 'session.name' ])) {
$sessionConfig [ 'ini' ][ 'session.name' ] = $sessionConfig [ 'cookie' ];
}
if ( ! empty ( $sessionConfig [ 'handler' ])) {
2010-07-25 01:14:41 -04:00
$sessionConfig [ 'ini' ][ 'session.save_handler' ] = 'user' ;
2008-05-30 11:40:08 +00:00
}
2010-07-25 00:42:28 -04:00
if ( empty ( $_SESSION )) {
if ( ! empty ( $sessionConfig [ 'ini' ]) && is_array ( $sessionConfig [ 'ini' ])) {
foreach ( $sessionConfig [ 'ini' ] as $setting => $value ) {
if ( ini_set ( $setting , $value ) === false ) {
2010-12-11 19:01:07 -05:00
throw new CakeSessionException ( sprintf (
2011-03-20 16:35:43 +01:00
__d ( 'cake_dev' , 'Unable to configure the session, setting %s failed.' ),
2010-07-25 11:42:05 -04:00
$setting
));
2010-07-25 00:42:28 -04:00
}
}
}
}
if ( ! empty ( $sessionConfig [ 'handler' ]) && ! isset ( $sessionConfig [ 'handler' ][ 'engine' ])) {
call_user_func_array ( 'session_set_save_handler' , $sessionConfig [ 'handler' ]);
}
2010-07-25 11:42:05 -04:00
if ( ! empty ( $sessionConfig [ 'handler' ][ 'engine' ])) {
2010-09-06 00:43:58 -04:00
$handler = self :: _getHandler ( $sessionConfig [ 'handler' ][ 'engine' ]);
2010-07-25 11:42:05 -04:00
session_set_save_handler (
2010-09-06 00:43:58 -04:00
array ( $handler , 'open' ),
array ( $handler , 'close' ),
array ( $handler , 'read' ),
array ( $handler , 'write' ),
array ( $handler , 'destroy' ),
array ( $handler , 'gc' )
2010-07-25 11:42:05 -04:00
);
}
2010-07-26 00:32:31 -04:00
Configure :: write ( 'Session' , $sessionConfig );
self :: $sessionTime = self :: $time + ( $sessionConfig [ 'timeout' ] * 60 );
2010-07-25 14:27:45 -04:00
}
2008-05-30 11:40:08 +00:00
2010-07-25 14:27:45 -04:00
/**
* Find the handler class and make sure it implements the correct interface .
*
2011-07-30 18:38:57 -04:00
* @ param string $handler
2010-07-25 14:27:45 -04:00
* @ return void
2011-07-31 16:55:52 -04:00
* @ throws CakeSessionException
2010-07-25 14:27:45 -04:00
*/
protected static function _getHandler ( $handler ) {
2010-07-25 19:09:29 -04:00
list ( $plugin , $class ) = pluginSplit ( $handler , true );
2010-12-07 19:59:07 -04:30
App :: uses ( $class , $plugin . 'Model/Datasource/Session' );
2010-07-25 14:27:45 -04:00
if ( ! class_exists ( $class )) {
2011-03-20 16:35:43 +01:00
throw new CakeSessionException ( __d ( 'cake_dev' , 'Could not load %s to handle the session.' , $class ));
2008-05-30 11:40:08 +00:00
}
2010-09-06 00:43:58 -04:00
$handler = new $class ();
if ( $handler instanceof CakeSessionHandlerInterface ) {
return $handler ;
2010-07-25 14:27:45 -04:00
}
2011-03-20 16:35:43 +01:00
throw new CakeSessionException ( __d ( 'cake_dev' , 'Chosen SessionHandler does not implement CakeSessionHandlerInterface it cannot be used with an engine key.' ));
2010-07-25 00:42:28 -04:00
}
/**
* Get one of the prebaked default session configurations .
*
2011-07-30 18:38:57 -04:00
* @ param string $name
* @ return boolean | array
2010-07-25 00:42:28 -04:00
*/
protected static function _defaultConfig ( $name ) {
$defaults = array (
'php' => array (
'cookie' => 'CAKEPHP' ,
'timeout' => 240 ,
'cookieTimeout' => 240 ,
'ini' => array (
'session.use_trans_sid' => 0 ,
2011-11-09 16:38:36 +02:00
'session.cookie_path' => self :: $path
2010-07-25 00:42:28 -04:00
)
),
'cake' => array (
'cookie' => 'CAKEPHP' ,
'timeout' => 240 ,
'cookieTimeout' => 240 ,
'ini' => array (
'session.use_trans_sid' => 0 ,
'url_rewriter.tags' => '' ,
'session.serialize_handler' => 'php' ,
'session.use_cookies' => 1 ,
'session.cookie_path' => self :: $path ,
'session.auto_start' => 0 ,
2010-07-25 01:14:41 -04:00
'session.save_path' => TMP . 'sessions' ,
'session.save_handler' => 'files'
2010-07-25 00:42:28 -04:00
)
),
'cache' => array (
'cookie' => 'CAKEPHP' ,
'timeout' => 240 ,
'cookieTimeout' => 240 ,
'ini' => array (
'session.use_trans_sid' => 0 ,
'url_rewriter.tags' => '' ,
2010-07-25 01:14:41 -04:00
'session.auto_start' => 0 ,
2010-07-25 00:42:28 -04:00
'session.use_cookies' => 1 ,
'session.cookie_path' => self :: $path ,
'session.save_handler' => 'user' ,
),
'handler' => array (
2010-07-25 13:20:30 -04:00
'engine' => 'CacheSession' ,
'config' => 'default'
2010-07-25 00:42:28 -04:00
)
),
'database' => array (
'cookie' => 'CAKEPHP' ,
'timeout' => 240 ,
'cookieTimeout' => 240 ,
'ini' => array (
'session.use_trans_sid' => 0 ,
'url_rewriter.tags' => '' ,
'session.auto_start' => 0 ,
'session.use_cookies' => 1 ,
'session.cookie_path' => self :: $path ,
'session.save_handler' => 'user' ,
'session.serialize_handler' => 'php' ,
),
'handler' => array (
2010-07-25 13:20:30 -04:00
'engine' => 'DatabaseSession' ,
'model' => 'Session'
2010-07-25 00:42:28 -04:00
)
)
);
if ( isset ( $defaults [ $name ])) {
return $defaults [ $name ];
}
return false ;
2008-05-30 11:40:08 +00:00
}
2009-07-24 21:18:37 +02:00
2008-05-30 11:40:08 +00:00
/**
* Helper method to start a session
*
2010-07-07 17:56:23 +10:00
* @ return boolean Success
2008-05-30 11:40:08 +00:00
*/
2010-11-08 22:35:31 -04:30
protected static function _startSession () {
2008-05-30 11:40:08 +00:00
if ( headers_sent ()) {
2009-01-14 03:52:37 +00:00
if ( empty ( $_SESSION )) {
2008-05-30 11:40:08 +00:00
$_SESSION = array ();
}
} elseif ( ! isset ( $_SESSION )) {
session_cache_limiter ( " must-revalidate " );
session_start ();
header ( 'P3P: CP="NOI ADM DEV PSAi COM NAV OUR OTRo STP IND DEM"' );
} else {
session_start ();
}
2010-07-07 17:56:23 +10:00
return true ;
2008-05-30 11:40:08 +00:00
}
2009-07-24 21:18:37 +02:00
2008-05-30 11:40:08 +00:00
/**
* Helper method to create a new session .
*
2008-09-25 16:49:56 +00:00
* @ return void
2008-05-30 11:40:08 +00:00
*/
2010-06-23 11:25:04 +10:00
protected static function _checkValid () {
2010-12-09 23:55:38 -05:00
if ( ! self :: started () && ! self :: start ()) {
self :: $valid = false ;
return false ;
}
2010-12-06 09:38:06 -04:30
if ( $config = self :: read ( 'Config' )) {
2010-07-25 17:50:08 -04:00
$sessionConfig = Configure :: read ( 'Session' );
2010-07-26 22:38:40 -04:00
2010-07-26 23:01:23 -04:00
if ( self :: _validAgentAndTime ()) {
2010-12-06 09:38:06 -04:30
$time = $config [ 'time' ];
2010-06-23 11:25:04 +10:00
self :: write ( 'Config.time' , self :: $sessionTime );
2010-07-26 22:42:32 -04:00
if ( isset ( $sessionConfig [ 'autoRegenerate' ]) && $sessionConfig [ 'autoRegenerate' ] === true ) {
2010-12-06 09:38:06 -04:30
$check = $config [ 'countdown' ];
2010-05-11 00:39:10 -04:00
$check -= 1 ;
2010-07-25 17:50:08 -04:00
self :: write ( 'Config.countdown' , $check );
2008-05-30 11:40:08 +00:00
2010-07-25 17:50:08 -04:00
if ( time () > ( $time - ( $sessionConfig [ 'timeout' ] * 60 ) + 2 ) || $check < 1 ) {
2010-06-23 11:25:04 +10:00
self :: renew ();
2010-07-25 17:50:08 -04:00
self :: write ( 'Config.countdown' , self :: $requestCountdown );
2008-05-30 11:40:08 +00:00
}
}
2010-06-23 11:25:04 +10:00
self :: $valid = true ;
2008-05-30 11:40:08 +00:00
} else {
2010-06-23 11:25:04 +10:00
self :: destroy ();
self :: $valid = false ;
2011-08-20 00:43:34 -04:00
self :: _setError ( 1 , 'Session Highjacking Attempted !!!' );
2008-05-30 11:40:08 +00:00
}
} else {
2010-06-23 11:25:04 +10:00
self :: write ( 'Config.userAgent' , self :: $_userAgent );
self :: write ( 'Config.time' , self :: $sessionTime );
2010-07-25 17:50:08 -04:00
self :: write ( 'Config.countdown' , self :: $requestCountdown );
2010-06-23 11:25:04 +10:00
self :: $valid = true ;
2008-05-30 11:40:08 +00:00
}
}
2009-07-24 21:18:37 +02:00
2008-05-30 11:40:08 +00:00
/**
2010-07-22 18:14:49 +10:00
* Restarts this session .
2008-05-30 11:40:08 +00:00
*
2008-09-25 16:49:56 +00:00
* @ return void
2008-05-30 11:40:08 +00:00
*/
2010-07-22 18:14:49 +10:00
public static function renew () {
2010-07-22 17:53:47 +10:00
if ( session_id ()) {
if ( session_id () != '' || isset ( $_COOKIE [ session_name ()])) {
2010-06-23 11:25:04 +10:00
setcookie ( Configure :: read ( 'Session.cookie' ), '' , time () - 42000 , self :: $path );
2008-05-30 11:40:08 +00:00
}
2008-10-12 03:29:10 +00:00
session_regenerate_id ( true );
2008-05-30 11:40:08 +00:00
}
}
2009-07-24 21:18:37 +02:00
2008-05-30 11:40:08 +00:00
/**
* Helper method to set an internal error message .
*
* @ param integer $errorNumber Number of the error
* @ param string $errorMessage Description of the error
2008-09-25 16:49:56 +00:00
* @ return void
2008-05-30 11:40:08 +00:00
*/
2011-08-20 00:43:34 -04:00
protected static function _setError ( $errorNumber , $errorMessage ) {
2010-06-23 11:25:04 +10:00
if ( self :: $error === false ) {
self :: $error = array ();
2008-05-30 11:40:08 +00:00
}
2010-06-23 11:25:04 +10:00
self :: $error [ $errorNumber ] = $errorMessage ;
self :: $lastError = $errorNumber ;
2008-05-30 11:40:08 +00:00
}
2010-07-25 11:42:05 -04:00
}
/**
* Interface for Session handlers . Custom session handler classes should implement
* this interface as it allows CakeSession know how to map methods to session_set_save_handler ()
*
2011-07-26 01:46:14 -04:30
* @ package Cake . Model . Datasource
2010-07-25 11:42:05 -04:00
*/
interface CakeSessionHandlerInterface {
/**
* Method called on open of a session .
*
* @ return boolean Success
*/
2010-09-06 00:43:58 -04:00
public function open ();
2010-07-25 11:42:05 -04:00
/**
* Method called on close of a session .
*
* @ return boolean Success
*/
2010-09-06 00:43:58 -04:00
public function close ();
2010-07-25 11:42:05 -04:00
/**
* Method used to read from a session .
*
* @ param mixed $id The key of the value to read
* @ return mixed The value of the key or false if it does not exist
*/
2010-09-06 00:43:58 -04:00
public function read ( $id );
2010-07-25 11:42:05 -04:00
/**
* Helper function called on write for sessions .
*
* @ param integer $id ID that uniquely identifies session in database
* @ param mixed $data The value of the data to be saved .
* @ return boolean True for successful write , false otherwise .
*/
2010-09-06 00:43:58 -04:00
public function write ( $id , $data );
2010-07-25 11:42:05 -04:00
/**
* Method called on the destruction of a session .
*
* @ param integer $id ID that uniquely identifies session in database
* @ return boolean True for successful delete , false otherwise .
*/
2010-09-06 00:43:58 -04:00
public function destroy ( $id );
2010-07-25 11:42:05 -04:00
/**
* Run the Garbage collection on the session storage . This method should vacuum all
* expired or dead sessions .
*
* @ param integer $expires Timestamp ( defaults to current time )
* @ return boolean Success
*/
2010-09-06 00:43:58 -04:00
public function gc ( $expires = null );
2010-07-25 11:42:05 -04:00
}
2010-07-04 20:06:24 +10:00
// Initialize the session
CakeSession :: init ();