blob: 9fad08cf9921401c3b18f4a297d17708bd960d52 [file] [log] [blame]
Derek Jones0b59f272008-05-13 04:22:33 +00001<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');
Derek Allardd2df9bc2007-04-15 17:41:17 +00002/**
3 * CodeIgniter
4 *
5 * An open source application development framework for PHP 4.3.2 or newer
6 *
7 * @package CodeIgniter
Derek Allard3d879d52008-01-18 19:41:32 +00008 * @author ExpressionEngine Dev Team
Derek Allardd2df9bc2007-04-15 17:41:17 +00009 * @copyright Copyright (c) 2006, EllisLab, Inc.
Derek Jones7a9193a2008-01-21 18:39:20 +000010 * @license http://codeigniter.com/user_guide/license.html
11 * @link http://codeigniter.com
Derek Allardd2df9bc2007-04-15 17:41:17 +000012 * @since Version 1.0
13 * @filesource
14 */
15
16// ------------------------------------------------------------------------
17
18/**
19 * Session Class
20 *
21 * @package CodeIgniter
22 * @subpackage Libraries
23 * @category Sessions
Derek Allard3d879d52008-01-18 19:41:32 +000024 * @author ExpressionEngine Dev Team
Derek Jones7a9193a2008-01-21 18:39:20 +000025 * @link http://codeigniter.com/user_guide/libraries/sessions.html
Derek Allardd2df9bc2007-04-15 17:41:17 +000026 */
27class CI_Session {
28
Rick Ellis44984d62008-08-20 22:26:07 +000029 var $sess_encrypt_cookie = FALSE;
30 var $sess_use_database = FALSE;
31 var $sess_table_name = '';
32 var $sess_expiration = 7200;
33 var $sess_match_ip = FALSE;
34 var $sess_match_useragent = TRUE;
35 var $sess_cookie_name = 'ci_session';
36 var $cookie_prefix = '';
37 var $cookie_path = '';
38 var $cookie_domain = '';
39 var $sess_time_to_update = 300;
40 var $encryption_key = '';
41 var $flashdata_key = 'flash';
42 var $time_reference = 'time';
43 var $gc_probability = 5;
44 var $userdata = array();
Derek Allardd2df9bc2007-04-15 17:41:17 +000045 var $CI;
46 var $now;
Derek Allardd2df9bc2007-04-15 17:41:17 +000047
48 /**
49 * Session Constructor
50 *
51 * The constructor runs the session routines automatically
52 * whenever the class is instantiated.
53 */
Rick Ellis44984d62008-08-20 22:26:07 +000054 function CI_Session($params = array())
Derek Allardd2df9bc2007-04-15 17:41:17 +000055 {
Derek Allardd2df9bc2007-04-15 17:41:17 +000056 log_message('debug', "Session Class Initialized");
Derek Allard428e9642007-08-10 03:16:16 +000057
Rick Ellis44984d62008-08-20 22:26:07 +000058 // Set the super object to a local variable for use throughout the class
59 $this->CI =& get_instance();
60
61 // Set all the session preferences, which can either be set
62 // manually via the $params array above or via the config file
63 foreach (array('sess_encrypt_cookie', 'sess_use_database', 'sess_table_name', 'sess_expiration', 'sess_match_ip', 'sess_match_useragent', 'sess_cookie_name', 'cookie_path', 'cookie_domain', 'sess_time_to_update', 'time_reference', 'cookie_prefix', 'encryption_key') as $key)
Derek Allard428e9642007-08-10 03:16:16 +000064 {
Rick Ellis44984d62008-08-20 22:26:07 +000065 $this->$key = (isset($params[$key])) ? $params[$key] : $this->CI->config->item($key);
66 }
67
68 // Load the string helper so we can use the strip_slashes() function
69 $this->CI->load->helper('string');
Derek Allard428e9642007-08-10 03:16:16 +000070
Rick Ellis44984d62008-08-20 22:26:07 +000071 // Do we need encryption? If so, load the encryption class
Derek Allard993925b2008-08-21 12:43:31 +000072 if ($this->sess_encrypt_cookie == TRUE)
Derek Allardd2df9bc2007-04-15 17:41:17 +000073 {
74 $this->CI->load->library('encrypt');
Derek Allard993925b2008-08-21 12:43:31 +000075 }
Derek Allardd2df9bc2007-04-15 17:41:17 +000076
Rick Ellis44984d62008-08-20 22:26:07 +000077 // Are we using a database? If so, load it
78 if ($this->sess_use_database === TRUE AND $this->sess_table_name != '')
Derek Allardd2df9bc2007-04-15 17:41:17 +000079 {
Derek Allardd2df9bc2007-04-15 17:41:17 +000080 $this->CI->load->database();
81 }
Rick Ellis44984d62008-08-20 22:26:07 +000082
83 // Set the "now" time. Can either be GMT or server time, based on the
84 // config prefs. We use this to set the "last activity" time
85 $this->now = $this->_get_time();
86
87 // Set the session length. If the session expiration is
88 // set to zero we'll set the expiration two years from now.
89 if ($this->sess_expiration == 0)
Derek Allardd2df9bc2007-04-15 17:41:17 +000090 {
Rick Ellis44984d62008-08-20 22:26:07 +000091 $this->sess_expiration = (60*60*24*365*2);
Derek Allardd2df9bc2007-04-15 17:41:17 +000092 }
Rick Ellis44984d62008-08-20 22:26:07 +000093
94 // Set the cookie name
95 $this->sess_cookie_name = $this->cookie_prefix.$this->sess_cookie_name;
Derek Allardd2df9bc2007-04-15 17:41:17 +000096
Rick Ellis44984d62008-08-20 22:26:07 +000097 // Run the Session routine. If a session doesn't exist we'll
98 // create a new one. If it does, we'll update it.
Derek Jones0b59f272008-05-13 04:22:33 +000099 if ( ! $this->sess_read())
Derek Allardd2df9bc2007-04-15 17:41:17 +0000100 {
101 $this->sess_create();
102 }
103 else
104 {
Rick Ellis44984d62008-08-20 22:26:07 +0000105 $this->sess_update();
Derek Allardd2df9bc2007-04-15 17:41:17 +0000106 }
107
Derek Allard428e9642007-08-10 03:16:16 +0000108 // Delete 'old' flashdata (from last request)
Derek Allard993925b2008-08-21 12:43:31 +0000109 $this->_flashdata_sweep();
110
111 // Mark all new flashdata as old (data will be deleted before next request)
112 $this->_flashdata_mark();
Rick Ellis44984d62008-08-20 22:26:07 +0000113
114 // Delete expired sessions if necessary
115 $this->_sess_gc();
116
117 log_message('debug', "Session routines successfully run");
Derek Allardd2df9bc2007-04-15 17:41:17 +0000118 }
119
120 // --------------------------------------------------------------------
121
122 /**
123 * Fetch the current session data if it exists
124 *
125 * @access public
126 * @return void
127 */
128 function sess_read()
129 {
130 // Fetch the cookie
Rick Ellis44984d62008-08-20 22:26:07 +0000131 $session = $this->CI->input->cookie($this->sess_cookie_name);
Derek Allardd2df9bc2007-04-15 17:41:17 +0000132
Rick Ellis44984d62008-08-20 22:26:07 +0000133 // No cookie? Goodbye cruel world!...
Derek Allardd2df9bc2007-04-15 17:41:17 +0000134 if ($session === FALSE)
135 {
136 log_message('debug', 'A session cookie was not found.');
137 return FALSE;
138 }
139
Rick Ellis44984d62008-08-20 22:26:07 +0000140 // Decrypt the cookie data
141 if ($this->sess_encrypt_cookie == TRUE)
Derek Allardd2df9bc2007-04-15 17:41:17 +0000142 {
143 $session = $this->CI->encrypt->decode($session);
144 }
Derek Allard9c4280b2008-03-18 00:01:52 +0000145 else
146 {
147 // encryption was not used, so we need to check the md5 hash
Rick Ellis44984d62008-08-20 22:26:07 +0000148 $hash = substr($session, strlen($session)-32); // get last 32 chars
Derek Allard9c4280b2008-03-18 00:01:52 +0000149 $session = substr($session, 0, strlen($session)-32);
Derek Allardd2df9bc2007-04-15 17:41:17 +0000150
Rick Ellis44984d62008-08-20 22:26:07 +0000151 // Does the md5 hash match? This is to prevent manipulation of session data in userspace
152 if ($hash !== md5($session.$this->encryption_key))
Derek Allard9c4280b2008-03-18 00:01:52 +0000153 {
154 log_message('error', 'The session cookie data did not match what was expected. This could be a possible hacking attempt.');
155 $this->sess_destroy();
156 return FALSE;
157 }
158 }
159
Rick Ellis44984d62008-08-20 22:26:07 +0000160 // Unserialize the session array
161 $session = @unserialize(strip_slashes($session));
Derek Allardd2df9bc2007-04-15 17:41:17 +0000162
Rick Ellis44984d62008-08-20 22:26:07 +0000163 // Is the session data we unserialized and array with the correct format?
164 if ( ! is_array($session) OR ! isset($session['session_id']) OR ! isset($session['ip_address']) OR ! isset($session['user_agent']) OR ! isset($session['last_activity']))
Derek Allardd2df9bc2007-04-15 17:41:17 +0000165 {
Rick Ellis44984d62008-08-20 22:26:07 +0000166 $this->sess_destroy();
Derek Allardd2df9bc2007-04-15 17:41:17 +0000167 return FALSE;
168 }
169
170 // Is the session current?
Rick Ellis44984d62008-08-20 22:26:07 +0000171 if (($session['last_activity'] + $this->sess_expiration) < $this->now)
Derek Allardd2df9bc2007-04-15 17:41:17 +0000172 {
173 $this->sess_destroy();
174 return FALSE;
175 }
176
177 // Does the IP Match?
Rick Ellis44984d62008-08-20 22:26:07 +0000178 if ($this->sess_match_ip == TRUE AND $session['ip_address'] != $this->CI->input->ip_address())
Derek Allardd2df9bc2007-04-15 17:41:17 +0000179 {
180 $this->sess_destroy();
181 return FALSE;
182 }
183
184 // Does the User Agent Match?
Rick Ellis44984d62008-08-20 22:26:07 +0000185 if ($this->sess_match_useragent == TRUE AND trim($session['user_agent']) != trim(substr($this->CI->input->user_agent(), 0, 50)))
Derek Allardd2df9bc2007-04-15 17:41:17 +0000186 {
187 $this->sess_destroy();
188 return FALSE;
189 }
190
191 // Is there a corresponding session in the DB?
Rick Ellis44984d62008-08-20 22:26:07 +0000192 if ($this->sess_use_database === TRUE)
Derek Allardd2df9bc2007-04-15 17:41:17 +0000193 {
194 $this->CI->db->where('session_id', $session['session_id']);
195
Rick Ellis44984d62008-08-20 22:26:07 +0000196 if ($this->sess_match_ip == TRUE)
Derek Allardd2df9bc2007-04-15 17:41:17 +0000197 {
198 $this->CI->db->where('ip_address', $session['ip_address']);
199 }
200
Rick Ellis44984d62008-08-20 22:26:07 +0000201 if ($this->sess_match_useragent == TRUE)
Derek Allardd2df9bc2007-04-15 17:41:17 +0000202 {
203 $this->CI->db->where('user_agent', $session['user_agent']);
204 }
205
Rick Ellis44984d62008-08-20 22:26:07 +0000206 $query = $this->CI->db->get($this->sess_table_name);
Derek Allardd2df9bc2007-04-15 17:41:17 +0000207
Rick Ellis44984d62008-08-20 22:26:07 +0000208 // No result? Kill it!
Derek Allardd2df9bc2007-04-15 17:41:17 +0000209 if ($query->num_rows() == 0)
210 {
211 $this->sess_destroy();
212 return FALSE;
213 }
Rick Ellis44984d62008-08-20 22:26:07 +0000214
215 // Is there custom data? If so, add it to the main session array
216 $row = $query->row();
217 if (isset($row->user_data) AND $row->user_data != '')
Derek Allardd2df9bc2007-04-15 17:41:17 +0000218 {
Rick Ellis44984d62008-08-20 22:26:07 +0000219 $custom_data = @unserialize(strip_slashes($row->user_data));
220
221 if (is_array($custom_data))
Derek Allardd2df9bc2007-04-15 17:41:17 +0000222 {
Rick Ellis44984d62008-08-20 22:26:07 +0000223 foreach ($custom_data as $key => $val)
224 {
225 $session[$key] = $val;
226 }
Derek Allardd2df9bc2007-04-15 17:41:17 +0000227 }
Rick Ellis44984d62008-08-20 22:26:07 +0000228 }
Derek Allardd2df9bc2007-04-15 17:41:17 +0000229 }
230
231 // Session is valid!
232 $this->userdata = $session;
233 unset($session);
234
235 return TRUE;
236 }
237
238 // --------------------------------------------------------------------
239
240 /**
Rick Ellis44984d62008-08-20 22:26:07 +0000241 * Write the session data
Derek Allardd2df9bc2007-04-15 17:41:17 +0000242 *
243 * @access public
244 * @return void
245 */
246 function sess_write()
Rick Ellis44984d62008-08-20 22:26:07 +0000247 {
248 // Are we saving custom data to the DB? If not, all we do is update the cookie
249 if ($this->sess_use_database === FALSE)
Derek Allardd2df9bc2007-04-15 17:41:17 +0000250 {
Rick Ellis44984d62008-08-20 22:26:07 +0000251 $this->_set_cookie();
252 return;
253 }
254
255 // We need two copies of the session data array. One will contain any custom data
256 // that might have been set. The other will contain the data that will be saved to the cookie
257 $cookie_userdata = $this->userdata;
258 $custom_userdata = $this->userdata;
259
260 // Before continuing, we need to determine if there is any custom data to deal with.
261 // Let's determine this by removing the default indexes to see if there's anything left in the array
262 foreach (array('session_id','ip_address','user_agent','last_activity') as $val)
263 {
264 unset($custom_userdata[$val]);
265 }
266
267 // Did we find any custom data? If not, we turn the empty array into a string
268 // since there's no reason to serialize and store an empty array in the DB
269 if (count($custom_userdata) === 0)
270 {
271 $custom_userdata = '';
Derek Allardd2df9bc2007-04-15 17:41:17 +0000272 }
Derek Allard9c4280b2008-03-18 00:01:52 +0000273 else
274 {
Rick Ellis44984d62008-08-20 22:26:07 +0000275 // Before we serialize the custom data array, let's remove that data from the
276 // main session array since we do not want to save that info to the cookie
277 foreach (array_keys($custom_userdata) as $val)
278 {
279 unset($cookie_userdata[$val]);
280 }
281
282 // Serialize the custom data array so we can store it
283 $custom_userdata = serialize($custom_userdata);
Derek Allard9c4280b2008-03-18 00:01:52 +0000284 }
Rick Ellis44984d62008-08-20 22:26:07 +0000285
286 // Run the update query
287 $this->CI->db->where('session_id', $this->userdata['session_id']);
288 $this->CI->db->update($this->sess_table_name, array('last_activity' => $this->userdata['last_activity'], 'user_data' => $custom_userdata));
Derek Allardd2df9bc2007-04-15 17:41:17 +0000289
Rick Ellis44984d62008-08-20 22:26:07 +0000290 // Write the cookie. Notice that we manually pass the cookie data array to the
291 // _set_cookie() function. Normally that function will store $this->userdata, but
292 // in this case that array contains custom data, which we do not want in the cookie.
293 $this->_set_cookie($cookie_userdata);
Derek Allardd2df9bc2007-04-15 17:41:17 +0000294 }
Rick Ellis44984d62008-08-20 22:26:07 +0000295
Derek Allardd2df9bc2007-04-15 17:41:17 +0000296 // --------------------------------------------------------------------
297
298 /**
299 * Create a new session
300 *
301 * @access public
302 * @return void
303 */
304 function sess_create()
305 {
306 $sessid = '';
307 while (strlen($sessid) < 32)
308 {
309 $sessid .= mt_rand(0, mt_getrandmax());
310 }
Rick Ellis44984d62008-08-20 22:26:07 +0000311
312 // To make the session ID even more secure we'll combine it with the user's IP
313 $sessid .= $this->CI->input->ip_address();
Derek Allardd2df9bc2007-04-15 17:41:17 +0000314
315 $this->userdata = array(
316 'session_id' => md5(uniqid($sessid, TRUE)),
317 'ip_address' => $this->CI->input->ip_address(),
318 'user_agent' => substr($this->CI->input->user_agent(), 0, 50),
319 'last_activity' => $this->now
320 );
321
322
Rick Ellis44984d62008-08-20 22:26:07 +0000323 // Save the data to the DB if needed
324 if ($this->sess_use_database === TRUE)
Derek Allardd2df9bc2007-04-15 17:41:17 +0000325 {
Rick Ellis44984d62008-08-20 22:26:07 +0000326 $this->CI->db->query($this->CI->db->insert_string($this->sess_table_name, $this->userdata));
Derek Allardd2df9bc2007-04-15 17:41:17 +0000327 }
328
329 // Write the cookie
Rick Ellis44984d62008-08-20 22:26:07 +0000330 $this->_set_cookie();
Derek Allardd2df9bc2007-04-15 17:41:17 +0000331 }
332
333 // --------------------------------------------------------------------
334
335 /**
336 * Update an existing session
337 *
338 * @access public
339 * @return void
340 */
341 function sess_update()
Rick Ellis44984d62008-08-20 22:26:07 +0000342 {
343 // We only update the session every five minutes by default
344 if (($this->userdata['last_activity'] + $this->sess_time_to_update) >= $this->now)
345 {
346 return;
347 }
348
Derek Allard428e9642007-08-10 03:16:16 +0000349 // Save the old session id so we know which record to
350 // update in the database if we need it
351 $old_sessid = $this->userdata['session_id'];
352 $new_sessid = '';
353 while (strlen($new_sessid) < 32)
354 {
355 $new_sessid .= mt_rand(0, mt_getrandmax());
356 }
Rick Ellis44984d62008-08-20 22:26:07 +0000357
358 // To make the session ID even more secure we'll combine it with the user's IP
359 $new_sessid .= $this->CI->input->ip_address();
360
361 // Turn it into a hash
Derek Allard428e9642007-08-10 03:16:16 +0000362 $new_sessid = md5(uniqid($new_sessid, TRUE));
363
Derek Allard993925b2008-08-21 12:43:31 +0000364 // Update the session data in the session data array
Derek Allard428e9642007-08-10 03:16:16 +0000365 $this->userdata['session_id'] = $new_sessid;
Derek Allardd2df9bc2007-04-15 17:41:17 +0000366 $this->userdata['last_activity'] = $this->now;
367
Rick Ellis44984d62008-08-20 22:26:07 +0000368 // Update the session ID and last_activity field in the DB if needed
369 if ($this->sess_use_database === TRUE)
370 {
371 $this->CI->db->query($this->CI->db->update_string($this->sess_table_name, array('last_activity' => $this->now, 'session_id' => $new_sessid), array('session_id' => $old_sessid)));
Derek Allardd2df9bc2007-04-15 17:41:17 +0000372 }
373
374 // Write the cookie
Rick Ellis44984d62008-08-20 22:26:07 +0000375 $this->_set_cookie();
Derek Allardd2df9bc2007-04-15 17:41:17 +0000376 }
377
378 // --------------------------------------------------------------------
379
380 /**
381 * Destroy the current session
382 *
383 * @access public
384 * @return void
385 */
386 function sess_destroy()
Rick Ellis44984d62008-08-20 22:26:07 +0000387 {
388 // Kill the session DB row
389 if ($this->sess_use_database === TRUE AND isset($this->userdata['session_id']))
390 {
391 $this->CI->db->where('session_id', $this->userdata['session_id']);
392 $this->CI->db->delete($this->sess_table_name);
393 }
394
395 // Kill the cookie
Derek Allardd2df9bc2007-04-15 17:41:17 +0000396 setcookie(
Rick Ellis44984d62008-08-20 22:26:07 +0000397 $this->sess_cookie_name,
Derek Allardd2df9bc2007-04-15 17:41:17 +0000398 addslashes(serialize(array())),
399 ($this->now - 31500000),
Rick Ellis44984d62008-08-20 22:26:07 +0000400 $this->cookie_path,
401 $this->cookie_domain,
Derek Allardd2df9bc2007-04-15 17:41:17 +0000402 0
403 );
404 }
405
406 // --------------------------------------------------------------------
407
408 /**
Derek Allard428e9642007-08-10 03:16:16 +0000409 * Fetch a specific item from the session array
Derek Allardd2df9bc2007-04-15 17:41:17 +0000410 *
411 * @access public
412 * @param string
413 * @return string
414 */
415 function userdata($item)
416 {
Derek Jones0b59f272008-05-13 04:22:33 +0000417 return ( ! isset($this->userdata[$item])) ? FALSE : $this->userdata[$item];
Derek Allardd2df9bc2007-04-15 17:41:17 +0000418 }
Derek Allard428e9642007-08-10 03:16:16 +0000419
420 // --------------------------------------------------------------------
421
422 /**
423 * Fetch all session data
424 *
425 * @access public
426 * @return mixed
427 */
428 function all_userdata()
429 {
Derek Allard993925b2008-08-21 12:43:31 +0000430 return ( ! isset($this->userdata)) ? FALSE : $this->userdata;
Derek Allard428e9642007-08-10 03:16:16 +0000431 }
Derek Allardd2df9bc2007-04-15 17:41:17 +0000432
433 // --------------------------------------------------------------------
434
435 /**
436 * Add or change data in the "userdata" array
437 *
438 * @access public
439 * @param mixed
440 * @param string
441 * @return void
442 */
443 function set_userdata($newdata = array(), $newval = '')
444 {
445 if (is_string($newdata))
446 {
447 $newdata = array($newdata => $newval);
448 }
449
450 if (count($newdata) > 0)
451 {
452 foreach ($newdata as $key => $val)
453 {
454 $this->userdata[$key] = $val;
455 }
456 }
Derek Allard428e9642007-08-10 03:16:16 +0000457
Derek Allardd2df9bc2007-04-15 17:41:17 +0000458 $this->sess_write();
459 }
460
461 // --------------------------------------------------------------------
462
463 /**
464 * Delete a session variable from the "userdata" array
465 *
Derek Allard428e9642007-08-10 03:16:16 +0000466 * @access array
Derek Allardd2df9bc2007-04-15 17:41:17 +0000467 * @return void
468 */
469 function unset_userdata($newdata = array())
470 {
471 if (is_string($newdata))
472 {
473 $newdata = array($newdata => '');
474 }
475
476 if (count($newdata) > 0)
477 {
478 foreach ($newdata as $key => $val)
479 {
480 unset($this->userdata[$key]);
481 }
482 }
483
484 $this->sess_write();
485 }
486
Derek Allard993925b2008-08-21 12:43:31 +0000487 // ------------------------------------------------------------------------
Derek Allard428e9642007-08-10 03:16:16 +0000488
Derek Allard993925b2008-08-21 12:43:31 +0000489 /**
Derek Allard428e9642007-08-10 03:16:16 +0000490 * Add or change flashdata, only available
491 * until the next request
492 *
493 * @access public
494 * @param mixed
495 * @param string
496 * @return void
497 */
Derek Allard993925b2008-08-21 12:43:31 +0000498 function set_flashdata($newdata = array(), $newval = '')
499 {
500 if (is_string($newdata))
501 {
502 $newdata = array($newdata => $newval);
503 }
504
505 if (count($newdata) > 0)
506 {
507 foreach ($newdata as $key => $val)
508 {
509 $flashdata_key = $this->flashdata_key.':new:'.$key;
510 $this->set_userdata($flashdata_key, $val);
511 }
512 }
513 }
Derek Allard428e9642007-08-10 03:16:16 +0000514
Derek Allard993925b2008-08-21 12:43:31 +0000515 // ------------------------------------------------------------------------
Derek Allard428e9642007-08-10 03:16:16 +0000516
Derek Allard993925b2008-08-21 12:43:31 +0000517 /**
518 * Keeps existing flashdata available to next request.
Derek Allard428e9642007-08-10 03:16:16 +0000519 *
520 * @access public
521 * @param string
522 * @return void
Derek Allard993925b2008-08-21 12:43:31 +0000523 */
524 function keep_flashdata($key)
525 {
Derek Allard428e9642007-08-10 03:16:16 +0000526 // 'old' flashdata gets removed. Here we mark all
527 // flashdata as 'new' to preserve it from _flashdata_sweep()
528 // Note the function will return FALSE if the $key
529 // provided cannot be found
Derek Allard993925b2008-08-21 12:43:31 +0000530 $old_flashdata_key = $this->flashdata_key.':old:'.$key;
531 $value = $this->userdata($old_flashdata_key);
Derek Allard428e9642007-08-10 03:16:16 +0000532
Derek Allard993925b2008-08-21 12:43:31 +0000533 $new_flashdata_key = $this->flashdata_key.':new:'.$key;
534 $this->set_userdata($new_flashdata_key, $value);
535 }
Derek Allard428e9642007-08-10 03:16:16 +0000536
Derek Allard993925b2008-08-21 12:43:31 +0000537 // ------------------------------------------------------------------------
Derek Allard428e9642007-08-10 03:16:16 +0000538
539 /**
540 * Fetch a specific flashdata item from the session array
541 *
542 * @access public
543 * @param string
544 * @return string
545 */
Derek Allard993925b2008-08-21 12:43:31 +0000546 function flashdata($key)
547 {
548 $flashdata_key = $this->flashdata_key.':old:'.$key;
549 return $this->userdata($flashdata_key);
550 }
Derek Allard428e9642007-08-10 03:16:16 +0000551
Derek Allard993925b2008-08-21 12:43:31 +0000552 // ------------------------------------------------------------------------
Derek Allard428e9642007-08-10 03:16:16 +0000553
Derek Allard993925b2008-08-21 12:43:31 +0000554 /**
555 * Identifies flashdata as 'old' for removal
Derek Allard428e9642007-08-10 03:16:16 +0000556 * when _flashdata_sweep() runs.
557 *
558 * @access private
559 * @return void
Derek Allard993925b2008-08-21 12:43:31 +0000560 */
561 function _flashdata_mark()
562 {
Derek Allard428e9642007-08-10 03:16:16 +0000563 $userdata = $this->all_userdata();
Derek Allard993925b2008-08-21 12:43:31 +0000564 foreach ($userdata as $name => $value)
565 {
566 $parts = explode(':new:', $name);
567 if (is_array($parts) && count($parts) === 2)
568 {
569 $new_name = $this->flashdata_key.':old:'.$parts[1];
570 $this->set_userdata($new_name, $value);
571 $this->unset_userdata($name);
572 }
573 }
574 }
Derek Allard428e9642007-08-10 03:16:16 +0000575
Derek Allard993925b2008-08-21 12:43:31 +0000576 // ------------------------------------------------------------------------
Derek Allard428e9642007-08-10 03:16:16 +0000577
Derek Allard993925b2008-08-21 12:43:31 +0000578 /**
579 * Removes all flashdata marked as 'old'
Derek Allard428e9642007-08-10 03:16:16 +0000580 *
581 * @access private
582 * @return void
Derek Allard993925b2008-08-21 12:43:31 +0000583 */
Derek Allard428e9642007-08-10 03:16:16 +0000584
Derek Allard993925b2008-08-21 12:43:31 +0000585 function _flashdata_sweep()
586 {
Derek Allard428e9642007-08-10 03:16:16 +0000587 $userdata = $this->all_userdata();
Derek Allard993925b2008-08-21 12:43:31 +0000588 foreach ($userdata as $key => $value)
589 {
590 if (strpos($key, ':old:'))
591 {
592 $this->unset_userdata($key);
593 }
594 }
Derek Allard428e9642007-08-10 03:16:16 +0000595
Derek Allard993925b2008-08-21 12:43:31 +0000596 }
Rick Ellis44984d62008-08-20 22:26:07 +0000597
598 // --------------------------------------------------------------------
599
600 /**
601 * Get the "now" time
602 *
603 * @access private
604 * @return string
605 */
606 function _get_time()
607 {
608 if (strtolower($this->time_reference) == 'gmt')
609 {
610 $now = time();
611 $time = mktime(gmdate("H", $now), gmdate("i", $now), gmdate("s", $now), gmdate("m", $now), gmdate("d", $now), gmdate("Y", $now));
612 }
613 else
614 {
615 $time = time();
616 }
617
618 return $time;
619 }
620
621 // --------------------------------------------------------------------
622
623 /**
624 * Write the session cookie
625 *
626 * @access public
627 * @return void
628 */
629 function _set_cookie($cookie_data = NULL)
630 {
631 if (is_null($cookie_data))
632 {
633 $cookie_data = $this->userdata;
634 }
635
636 // Serialize the userdata for the cookie
637 $cookie_data = serialize($cookie_data);
638
639 if ($this->sess_encrypt_cookie == TRUE)
640 {
641 $cookie_data = $this->CI->encrypt->encode($cookie_data);
642 }
643 else
644 {
645 // if encryption is not used, we provide an md5 hash to prevent userside tampering
646 $cookie_data = $cookie_data.md5($cookie_data.$this->encryption_key);
647 }
648
649 // Set the cookie
650 setcookie(
651 $this->sess_cookie_name,
652 $cookie_data,
653 $this->sess_expiration + time(),
654 $this->cookie_path,
655 $this->cookie_domain,
656 0
657 );
658 }
659
660 // --------------------------------------------------------------------
661
662 /**
663 * Garbage collection
664 *
665 * This deletes expired session rows from database
666 * if the probability percentage is met
667 *
668 * @access public
669 * @return void
670 */
671 function _sess_gc()
672 {
673 if ($this->sess_use_database != TRUE)
674 {
675 return;
676 }
677
678 srand(time());
679 if ((rand() % 100) < $this->gc_probability)
680 {
681 $expire = $this->now - $this->sess_expiration;
682
683 $this->CI->db->where("last_activity < {$expire}");
684 $this->CI->db->delete($this->sess_table_name);
685
686 log_message('debug', 'Session garbage collection performed.');
687 }
688 }
689
Derek Allard428e9642007-08-10 03:16:16 +0000690
Derek Allardd2df9bc2007-04-15 17:41:17 +0000691}
692// END Session Class
Derek Jones0b59f272008-05-13 04:22:33 +0000693
694/* End of file Session.php */
Derek Jonesa3ffbbb2008-05-11 18:18:29 +0000695/* Location: ./system/libraries/Session.php */