46 lines
1.3 KiB
PHP
46 lines
1.3 KiB
PHP
<?php
|
|
|
|
use EesyPHP\Log;
|
|
|
|
if (php_sapi_name() == "cli")
|
|
return true;
|
|
|
|
// Define session max duration
|
|
if (!isset($session_max_duration))
|
|
$session_max_duration = (12*60*60); // Default to 12h
|
|
ini_set('session.gc_maxlifetime', $session_max_duration);
|
|
ini_set('session.cookie_lifetime', $session_max_duration);
|
|
|
|
// Start session
|
|
session_start();
|
|
|
|
// Init session key
|
|
if (!isset($_SESSION['session_key'])) {
|
|
$_SESSION['session_key']=uniqid();
|
|
}
|
|
|
|
// Handle session timeout
|
|
if (isset($session_timeout) && $session_timeout) {
|
|
if (!isset($_SESSION['session_last_access'])) {
|
|
Log :: debug('Set initial session last access');
|
|
$_SESSION['session_last_access'] = time();
|
|
}
|
|
elseif ($_SESSION['session_last_access'] > (time() - $session_timeout)) {
|
|
Log :: debug(
|
|
'Session timeout not expired, update session last access '.
|
|
'(Previous value : '.$_SESSION['session_last_access'].')');
|
|
$_SESSION['session_last_access'] = time();
|
|
}
|
|
else {
|
|
Log :: info('Session destroyed due to inactivity');
|
|
session_destroy();
|
|
}
|
|
}
|
|
|
|
function check_session_key($value=null) {
|
|
if (is_null($value) && isset($_REQUEST['session_key']))
|
|
$value = $_REQUEST['session_key'];
|
|
return ($value && $_SESSION['session_key'] == $value);
|
|
}
|
|
|
|
# vim: tabstop=2 shiftwidth=2 softtabstop=2 expandtab
|