2017-06-24 00:58:56 +03:00
< ? php
/**
* AVE . cms
*
* @ package AVE . cms
* @ version 3. x
* @ filesource
* @ copyright © 2007 - 2014 AVE . cms , http :// www . ave - cms . ru
*
* @ license GPL v . 2
*/
class AVE_Session_DB
{
public $sess_lifetime ;
/**
* Хост
*
* @ var string
*/
protected $db_host ;
/**
* Имя пользователя
*
* @ var string
*/
protected $db_user ;
/**
* Пароль
*
* @ var string
*/
protected $db_pass ;
/**
* Имя текущей БД .
*
* @ var string
*/
protected $db_dbase ;
/**
* Префикс БД .
*
* @ var string
*/
protected $db_prefix ;
private $mysql_connect = null ;
private $mysql_db = null ;
/* Create a connection to a database */
function __construct ()
{
// Подключаем конфигурационный файл с параметрами подключения
require ( BASE_DIR . '/inc/db.config.php' );
$this -> db_host = $config [ 'dbhost' ];
$this -> db_user = $config [ 'dbuser' ];
$this -> db_pass = $config [ 'dbpass' ];
$this -> db_dbase = $config [ 'dbname' ];
$this -> db_prefix = $config [ 'dbpref' ];
$this -> sess_lifetime = ( defined ( 'SESSION_LIFETIME' ) && is_numeric ( SESSION_LIFETIME ))
? SESSION_LIFETIME
: ( get_cfg_var ( " session.gc_maxlifetime " ) < 1440
? 1440
: get_cfg_var ( " session.gc_maxlifetime " ));
if ( ! $this -> mysql_connect = mysqli_connect ( $this -> db_host , $this -> db_user , $this -> db_pass ))
{
$this -> error ();
}
if ( ! $this -> mysql_db = mysqli_select_db ( $this -> mysql_connect , $this -> db_dbase ))
{
$this -> error ();
}
$this -> mysql_connect -> set_charset ( 'utf8' );
return true ;
}
/* Open session */
function _open ( $path , $name )
{
return true ;
}
/* Close session */
function _close ()
{
@ mysqli_query ( $this -> mysql_connect , " DELETE FROM " . PREFIX . " _sessions WHERE expiry < ' " . time () . " ' " );
if ( $this -> mysql_connect !== null )
@ mysqli_close ( $this -> mysql_connect );
return true ;
}
/* Read session */
function _read ( $ses_id )
{
$qid = @ mysqli_query ( $this -> mysql_connect , " SELECT value, Ip FROM " . PREFIX . " _sessions WHERE sesskey = ' " . $ses_id . " ' AND expiry > ' " . time () . " ' " );
if (( list ( $value , $ip ) = @ mysqli_fetch_row ( $qid )) && $ip == $_SERVER [ 'REMOTE_ADDR' ])
{
return $value ;
}
return '' ;
}
/* Write new data */
function _write ( $ses_id , $data )
{
if ( ! $qid = @ mysqli_query ( $this -> mysql_connect , " INSERT INTO " . PREFIX . " _sessions VALUES (' " . $ses_id . " ', " . ( time () + $this -> sess_lifetime ) . " , ' " . addslashes ( $data ) . " ', ' " . $_SERVER [ 'REMOTE_ADDR' ] . " ', FROM_UNIXTIME(expiry, '%d.%m.%Y, %H:%i:%s')) " ))
{
$qid = @ mysqli_query ( $this -> mysql_connect , " UPDATE " . PREFIX . " _sessions SET expiry = " . ( time () + $this -> sess_lifetime ) . " , expire_datum = FROM_UNIXTIME(expiry,'%d.%m.%Y, %H:%i:%s'), value = ' " . addslashes ( $data ) . " ', Ip = ' " . $_SERVER [ 'REMOTE_ADDR' ] . " ' WHERE sesskey = ' " . $ses_id . " ' AND expiry > ' " . time () . " ' " );
}
return $qid ;
}
/* Destroy session */
function _destroy ( $ses_id )
{
return @ mysqli_query ( $this -> mysql_connect , " DELETE FROM " . PREFIX . " _sessions WHERE sesskey = ' " . $ses_id . " ' " );
}
/* Garbage collection, deletes old sessions */
function _gc ( $maxlifetime )
{
2017-11-17 12:02:05 +03:00
$session_res = @ mysqli_query ( $this -> mysql_connect , " DELETE FROM " . PREFIX . " _sessions WHERE expire < (UNIX_TIMESTAMP(NOW()) - " . ( int ) $maxlifetime . " ) " );
2017-06-24 00:58:56 +03:00
if ( ! $session_res ) {
return false ;
}
else
{
return true ;
}
}
function error () {
ob_start ();
header ( 'HTTP/1.1 503 Service Temporarily Unavailable' );
header ( 'Status: 503 Service Temporarily Unavailable' );
header ( 'Retry-After: 3600' );
header ( 'X-Powered-By:' );
display_notice ( " Error connect to MySQL. " );
die ;
}
}
?>