mirror of
https://github.com/LBRYFoundation/pool.git
synced 2025-10-01 07:40:41 +00:00
203 lines
5.9 KiB
PHP
203 lines
5.9 KiB
PHP
<?php
|
|
/**
|
|
* CDbHttpSession class
|
|
*
|
|
* @author Qiang Xue <qiang.xue@gmail.com>
|
|
* @link http://www.yiiframework.com/
|
|
* @copyright Copyright © 2008-2009 Yii Software LLC
|
|
* @license http://www.yiiframework.com/license/
|
|
*/
|
|
|
|
/**
|
|
* CDbHttpSession extends {@link CHttpSession} by using database as session data storage.
|
|
*
|
|
* CDbHttpSession stores session data in a DB table named 'YiiSession'. The table name
|
|
* can be changed by setting {@link sessionTableName}. If the table does not exist,
|
|
* it will be automatically created if {@link autoCreateSessionTable} is set true.
|
|
*
|
|
* CDbHttpSession relies on {@link http://www.php.net/manual/en/ref.pdo.php PDO} to access database.
|
|
*
|
|
* By default, it will use an SQLite3 database named 'session-YiiVersion.db' under the application runtime directory.
|
|
* You can also specify {@link connectionID} so that it makes use of a DB application component to access database.
|
|
*
|
|
* @author Qiang Xue <qiang.xue@gmail.com>
|
|
* @version $Id: CDbHttpSession.php 433 2008-12-30 22:59:17Z qiang.xue $
|
|
* @package system.web
|
|
* @since 1.0
|
|
*/
|
|
class CDbHttpSession extends CHttpSession
|
|
{
|
|
/**
|
|
* @var string the ID of a {@link CDbConnection} application component. If not set, a SQLite database
|
|
* will be automatically created and used. The SQLite database file is
|
|
* is <code>protected/runtime/session-YiiVersion.db</code>.
|
|
*/
|
|
public $connectionID;
|
|
/**
|
|
* @var string the name of the DB table to store session content.
|
|
* Note, if {@link autoCreateSessionTable} is false and you want to create the DB table manually by yourself,
|
|
* you need to make sure the DB table is of the following structure:
|
|
* <pre>
|
|
* (id CHAR(32) PRIMARY KEY, expire INTEGER, data TEXT)
|
|
* </pre>
|
|
* @see autoCreateSessionTable
|
|
*/
|
|
public $sessionTableName='YiiSession';
|
|
/**
|
|
* @var boolean whether the session DB table should be automatically created if not exists. Defaults to true.
|
|
* @see sessionTableName
|
|
*/
|
|
public $autoCreateSessionTable=true;
|
|
/**
|
|
* @var CDbConnection the DB connection instance
|
|
*/
|
|
private $_db;
|
|
|
|
|
|
/**
|
|
* Returns a value indicating whether to use custom session storage.
|
|
* This method overrides the parent implementation and always returns true.
|
|
* @return boolean whether to use custom storage.
|
|
*/
|
|
public function getUseCustomStorage()
|
|
{
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Creates the session DB table.
|
|
* @param CDbConnection the database connection
|
|
* @param string the name of the table to be created
|
|
*/
|
|
protected function createSessionTable($db,$tableName)
|
|
{
|
|
$sql="
|
|
CREATE TABLE $tableName
|
|
(
|
|
id CHAR(32) PRIMARY KEY,
|
|
expire INTEGER,
|
|
data TEXT
|
|
)";
|
|
$db->createCommand($sql)->execute();
|
|
}
|
|
|
|
/**
|
|
* @return CDbConnection the DB connection instance
|
|
* @throws CException if {@link connectionID} does not point to a valid application component.
|
|
*/
|
|
protected function getDbConnection()
|
|
{
|
|
if($this->_db!==null)
|
|
return $this->_db;
|
|
else if(($id=$this->connectionID)!==null)
|
|
{
|
|
if(($this->_db=Yii::app()->getComponent($id)) instanceof CDbConnection)
|
|
return $this->_db;
|
|
else
|
|
throw new CException(Yii::t('yii','CDbHttpSession.connectionID "{id}" is invalid. Please make sure it refers to the ID of a CDbConnection application component.',
|
|
array('{id}'=>$id)));
|
|
}
|
|
else
|
|
{
|
|
$dbFile=Yii::app()->getRuntimePath().DIRECTORY_SEPARATOR.'session-'.Yii::getVersion().'.db';
|
|
return $this->_db=new CDbConnection('sqlite:'.$dbFile);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Session open handler.
|
|
* Do not call this method directly.
|
|
* @param string session save path
|
|
* @param string session name
|
|
* @return boolean whether session is opened successfully
|
|
*/
|
|
public function openSession($savePath,$sessionName)
|
|
{
|
|
$db=$this->getDbConnection();
|
|
$db->setActive(true);
|
|
|
|
if($this->autoCreateSessionTable)
|
|
{
|
|
$sql="DELETE FROM {$this->sessionTableName} WHERE expire<".time();
|
|
try
|
|
{
|
|
$db->createCommand($sql)->execute();
|
|
}
|
|
catch(Exception $e)
|
|
{
|
|
$this->createSessionTable($db,$this->sessionTableName);
|
|
}
|
|
}
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Session read handler.
|
|
* Do not call this method directly.
|
|
* @param string session ID
|
|
* @return string the session data
|
|
*/
|
|
public function readSession($id)
|
|
{
|
|
$now=time();
|
|
$id=md5($id);
|
|
$sql="
|
|
SELECT data FROM {$this->sessionTableName}
|
|
WHERE expire>$now AND id='$id'
|
|
";
|
|
$data=$this->getDbConnection()->createCommand($sql)->queryScalar();
|
|
return $data===false?'':$data;
|
|
}
|
|
|
|
/**
|
|
* Session write handler.
|
|
* Do not call this method directly.
|
|
* @param string session ID
|
|
* @param string session data
|
|
* @return boolean whether session write is successful
|
|
*/
|
|
public function writeSession($id,$data)
|
|
{
|
|
$expire=time()+$this->getTimeout();
|
|
$id=md5($id);
|
|
$db=$this->getDbConnection();
|
|
$sql="SELECT id FROM {$this->sessionTableName} WHERE id='$id'";
|
|
if($db->createCommand($sql)->queryScalar()===false)
|
|
$sql="INSERT INTO {$this->sessionTableName} (id, data, expire) VALUES ('$id', :data, $expire)";
|
|
else
|
|
$sql="UPDATE {$this->sessionTableName} SET expire=$expire, data=:data WHERE id='$id'";
|
|
$command=$db->createCommand($sql);
|
|
$command->bindParam(':data',$data);
|
|
$command->execute();
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Session destroy handler.
|
|
* Do not call this method directly.
|
|
* @param string session ID
|
|
* @return boolean whether session is destroyed successfully
|
|
*/
|
|
public function destroySession($id)
|
|
{
|
|
$id=md5($id);
|
|
$sql="DELETE FROM {$this->sessionTableName} WHERE id='$id'";
|
|
$this->getDbConnection()->createCommand($sql)->execute();
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Session GC (garbage collection) handler.
|
|
* Do not call this method directly.
|
|
* @param integer the number of seconds after which data will be seen as 'garbage' and cleaned up.
|
|
* @return boolean whether session is GCed successfully
|
|
*/
|
|
public function gcSession($maxLifetime)
|
|
{
|
|
$db=$this->getDbConnection();
|
|
$db->setActive(true);
|
|
$sql="DELETE FROM {$this->sessionTableName} WHERE expire<".time();
|
|
$db->createCommand($sql)->execute();
|
|
return true;
|
|
}
|
|
}
|