164 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			164 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php defined('SYSPATH') OR die('No direct access allowed.');
 | |
| /**
 | |
|  * Session database driver.
 | |
|  *
 | |
|  * $Id: Database.php 3769 2008-12-15 00:48:56Z zombor $
 | |
|  *
 | |
|  * @package    Core
 | |
|  * @author     Kohana Team
 | |
|  * @copyright  (c) 2007-2008 Kohana Team
 | |
|  * @license    http://kohanaphp.com/license.html
 | |
|  */
 | |
| class Session_Database_Driver implements Session_Driver {
 | |
| 
 | |
| 	/*
 | |
| 	CREATE TABLE sessions
 | |
| 	(
 | |
| 		session_id VARCHAR(127) NOT NULL,
 | |
| 		last_activity INT(10) UNSIGNED NOT NULL,
 | |
| 		data TEXT NOT NULL,
 | |
| 		PRIMARY KEY (session_id)
 | |
| 	);
 | |
| 	*/
 | |
| 
 | |
| 	// Database settings
 | |
| 	protected $db = 'default';
 | |
| 	protected $table = 'sessions';
 | |
| 
 | |
| 	// Encryption
 | |
| 	protected $encrypt;
 | |
| 
 | |
| 	// Session settings
 | |
| 	protected $session_id;
 | |
| 	protected $written = FALSE;
 | |
| 
 | |
| 	public function __construct()
 | |
| 	{
 | |
| 		// Load configuration
 | |
| 		$config = Kohana::config('session');
 | |
| 
 | |
| 		if ( ! empty($config['encryption']))
 | |
| 		{
 | |
| 			// Load encryption
 | |
| 			$this->encrypt = Encrypt::instance();
 | |
| 		}
 | |
| 
 | |
| 		if (is_array($config['storage']))
 | |
| 		{
 | |
| 			if ( ! empty($config['storage']['group']))
 | |
| 			{
 | |
| 				// Set the group name
 | |
| 				$this->db = $config['storage']['group'];
 | |
| 			}
 | |
| 
 | |
| 			if ( ! empty($config['storage']['table']))
 | |
| 			{
 | |
| 				// Set the table name
 | |
| 				$this->table = $config['storage']['table'];
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		// Load database
 | |
| 		$this->db = Database::instance($this->db);
 | |
| 
 | |
| 		Kohana::log('debug', 'Session Database Driver Initialized');
 | |
| 	}
 | |
| 
 | |
| 	public function open($path, $name)
 | |
| 	{
 | |
| 		return TRUE;
 | |
| 	}
 | |
| 
 | |
| 	public function close()
 | |
| 	{
 | |
| 		return TRUE;
 | |
| 	}
 | |
| 
 | |
| 	public function read($id)
 | |
| 	{
 | |
| 		// Load the session
 | |
| 		$query = $this->db->from($this->table)->where('session_id', $id)->limit(1)->get()->result(TRUE);
 | |
| 
 | |
| 		if ($query->count() === 0)
 | |
| 		{
 | |
| 			// No current session
 | |
| 			$this->session_id = NULL;
 | |
| 
 | |
| 			return '';
 | |
| 		}
 | |
| 
 | |
| 		// Set the current session id
 | |
| 		$this->session_id = $id;
 | |
| 
 | |
| 		// Load the data
 | |
| 		$data = $query->current()->data;
 | |
| 
 | |
| 		return ($this->encrypt === NULL) ? base64_decode($data) : $this->encrypt->decode($data);
 | |
| 	}
 | |
| 
 | |
| 	public function write($id, $data)
 | |
| 	{
 | |
| 		$data = array
 | |
| 		(
 | |
| 			'session_id' => $id,
 | |
| 			'last_activity' => time(),
 | |
| 			'data' => ($this->encrypt === NULL) ? base64_encode($data) : $this->encrypt->encode($data)
 | |
| 		);
 | |
| 
 | |
| 		if ($this->session_id === NULL)
 | |
| 		{
 | |
| 			// Insert a new session
 | |
| 			$query = $this->db->insert($this->table, $data);
 | |
| 		}
 | |
| 		elseif ($id === $this->session_id)
 | |
| 		{
 | |
| 			// Do not update the session_id
 | |
| 			unset($data['session_id']);
 | |
| 
 | |
| 			// Update the existing session
 | |
| 			$query = $this->db->update($this->table, $data, array('session_id' => $id));
 | |
| 		}
 | |
| 		else
 | |
| 		{
 | |
| 			// Update the session and id
 | |
| 			$query = $this->db->update($this->table, $data, array('session_id' => $this->session_id));
 | |
| 
 | |
| 			// Set the new session id
 | |
| 			$this->session_id = $id;
 | |
| 		}
 | |
| 
 | |
| 		return (bool) $query->count();
 | |
| 	}
 | |
| 
 | |
| 	public function destroy($id)
 | |
| 	{
 | |
| 		// Delete the requested session
 | |
| 		$this->db->delete($this->table, array('session_id' => $id));
 | |
| 
 | |
| 		// Session id is no longer valid
 | |
| 		$this->session_id = NULL;
 | |
| 
 | |
| 		return TRUE;
 | |
| 	}
 | |
| 
 | |
| 	public function regenerate()
 | |
| 	{
 | |
| 		// Generate a new session id
 | |
| 		session_regenerate_id();
 | |
| 
 | |
| 		// Return new session id
 | |
| 		return session_id();
 | |
| 	}
 | |
| 
 | |
| 	public function gc($maxlifetime)
 | |
| 	{
 | |
| 		// Delete all expired sessions
 | |
| 		$query = $this->db->delete($this->table, array('last_activity <' => time() - $maxlifetime));
 | |
| 
 | |
| 		Kohana::log('debug', 'Session garbage collected: '.$query->count().' row(s) deleted.');
 | |
| 
 | |
| 		return TRUE;
 | |
| 	}
 | |
| 
 | |
| } // End Session Database Driver
 |