bludit/kernel/helpers/session.class.php

88 lines
1.8 KiB
PHP
Raw Normal View History

2015-05-05 01:00:01 +00:00
<?php defined('BLUDIT') or die('Bludit CMS.');
2015-03-08 14:02:59 -03:00
class Session {
2015-03-27 01:00:01 +00:00
private static $started = false;
2015-03-08 14:02:59 -03:00
2015-03-27 01:00:01 +00:00
public static function start()
2015-03-08 14:02:59 -03:00
{
2015-06-26 22:47:12 -03:00
//if(self::$started)
// return true;
2015-05-05 01:00:01 +00:00
// DEBUG: Ver un nombre con alguna llave random al momentode instalar.
$session_name = 'Bludit-KEY';
// If TRUE cookie will only be sent over secure connections.
$secure = false;
// If set to TRUE then PHP will attempt to send the httponly flag when setting the session cookie.
$httponly = true;
2015-06-26 22:47:12 -03:00
// This specifies the lifetime of the cookie in seconds which is sent to the browser.
// The value 0 means until the browser is closed.
$cookieLifetime = 0;
2015-05-05 01:00:01 +00:00
// Gets current cookies params.
$cookieParams = session_get_cookie_params();
2015-06-26 22:47:12 -03:00
session_set_cookie_params($cookieLifetime,
2015-05-14 22:07:45 +00:00
$cookieParams["path"],
$cookieParams["domain"],
2015-05-05 01:00:01 +00:00
$secure,
$httponly
);
// Sets the session name to the one set above.
session_name($session_name);
2015-05-14 22:07:45 +00:00
2015-05-05 01:00:01 +00:00
// Start session.
self::$started = session_start();
// Regenerated the session, delete the old one. There are problems with AJAX.
//session_regenerate_id(true);
2015-06-26 22:47:12 -03:00
if(self::$started) {
Log::set(__METHOD__.LOG_SEP.'Session started.');
}
else {
Log::set(__METHOD__.LOG_SEP.'Error occurred when trying to start the session.');
}
2015-03-08 14:02:59 -03:00
}
2015-03-27 01:00:01 +00:00
public static function started()
2015-03-08 14:02:59 -03:00
{
2015-03-27 01:00:01 +00:00
return self::$started;
2015-03-08 14:02:59 -03:00
}
2015-03-27 01:00:01 +00:00
public static function destroy()
2015-03-08 14:02:59 -03:00
{
2015-03-27 01:00:01 +00:00
session_destroy();
2015-03-08 14:02:59 -03:00
2015-03-27 01:00:01 +00:00
unset($_SESSION);
2015-05-14 22:07:45 +00:00
2015-03-27 01:00:01 +00:00
self::$started = false;
2015-05-14 22:07:45 +00:00
2015-06-26 22:47:12 -03:00
Log::set(__METHOD__.LOG_SEP.'Session destroyed.');
2015-05-14 22:07:45 +00:00
return !isset($_SESSION);
2015-03-08 14:02:59 -03:00
}
2015-03-27 01:00:01 +00:00
public static function set($key, $value)
2015-03-08 14:02:59 -03:00
{
2015-03-27 01:00:01 +00:00
$key = 's_'.$key;
2015-05-14 22:07:45 +00:00
2015-03-27 01:00:01 +00:00
$_SESSION[$key] = $value;
2015-03-08 14:02:59 -03:00
}
2015-03-27 01:00:01 +00:00
public static function get($key)
2015-03-08 14:02:59 -03:00
{
2015-03-27 01:00:01 +00:00
$key = 's_'.$key;
2015-03-08 14:02:59 -03:00
2015-06-26 22:47:12 -03:00
if( isset($_SESSION[$key]) ) {
2015-03-27 01:00:01 +00:00
return $_SESSION[$key];
2015-06-26 22:47:12 -03:00
}
2015-03-08 14:02:59 -03:00
return false;
}
}