mirror of
https://git.code.sf.net/p/seeddms/code
synced 2025-10-24 01:41:01 +00:00
516 lines
14 KiB
PHP
516 lines
14 KiB
PHP
<?php
|
|
/**
|
|
* Implementation of a simple session management.
|
|
*
|
|
* SeedDMS uses its own simple session management, storing sessions
|
|
* into the database. A session holds the currently logged in user,
|
|
* the theme and the language.
|
|
*
|
|
* @category DMS
|
|
* @package SeedDMS
|
|
* @license GPL 2
|
|
* @version @version@
|
|
* @author Uwe Steinmann <uwe@steinmann.cx>
|
|
* @copyright 2011 Uwe Steinmann
|
|
* @version Release: @package_version@
|
|
*/
|
|
|
|
/**
|
|
* Class to represent a session
|
|
*
|
|
* This class provides some very basic methods to load, save and delete
|
|
* sessions. It does not set or retrieve a cockie. This is up to the
|
|
* application. The class basically provides access to the session database
|
|
* table.
|
|
*
|
|
* @category DMS
|
|
* @package SeedDMS
|
|
* @author Markus Westphal, Malcolm Cowe, Uwe Steinmann <uwe@steinmann.cx>
|
|
* @copyright 2011 Uwe Steinmann
|
|
* @version Release: @package_version@
|
|
*/
|
|
class SeedDMS_Session {
|
|
/**
|
|
* @var object $db reference to database object. This must be an instance
|
|
* of {@link SeedDMS_Core_DatabaseAccess}.
|
|
* @access protected
|
|
*/
|
|
protected $db;
|
|
|
|
/**
|
|
* @var array $data session data
|
|
* @access protected
|
|
*/
|
|
protected $data;
|
|
|
|
/**
|
|
* @var string $id session id
|
|
* @access protected
|
|
*/
|
|
protected $id;
|
|
|
|
/**
|
|
* Create a new instance of the session handler
|
|
*
|
|
* @param object $db object to access the underlying database
|
|
* @return object instance of SeedDMS_Session
|
|
*/
|
|
function __construct($db) { /* {{{ */
|
|
$this->db = $db;
|
|
$this->id = false;
|
|
} /* }}} */
|
|
|
|
/**
|
|
* Load session by its id from database
|
|
*
|
|
* @param string $id id of session
|
|
* @return boolean true if successful otherwise false
|
|
*/
|
|
function load($id) { /* {{{ */
|
|
$queryStr = "SELECT * FROM `tblSessions` WHERE `id` = ".$this->db->qstr($id);
|
|
$resArr = $this->db->getResultArray($queryStr);
|
|
if (is_bool($resArr) && $resArr == false)
|
|
return false;
|
|
if (count($resArr) == 0)
|
|
return false;
|
|
$this->id = $id;
|
|
$this->data = array('userid'=>$resArr[0]['userID'], 'theme'=>$resArr[0]['theme'], 'lang'=>$resArr[0]['language'], 'id'=>$resArr[0]['id'], 'lastaccess'=>$resArr[0]['lastAccess'], 'su'=>$resArr[0]['su']);
|
|
if($resArr[0]['clipboard'])
|
|
$this->data['clipboard'] = json_decode($resArr[0]['clipboard'], true);
|
|
else
|
|
$this->data['clipboard'] = array('docs'=>array(), 'folders'=>array());
|
|
if($resArr[0]['splashmsg'])
|
|
$this->data['splashmsg'] = json_decode($resArr[0]['splashmsg'], true);
|
|
else
|
|
$this->data['splashmsg'] = array();
|
|
return $resArr[0];
|
|
} /* }}} */
|
|
|
|
/**
|
|
* Create a new session and saving the given data into the database
|
|
*
|
|
* @param array $data data saved in session (the only fields supported
|
|
* are userid, theme, language, su)
|
|
* @return string/boolean id of session of false in case of an error
|
|
*/
|
|
function create($data) { /* {{{ */
|
|
$id = "" . rand() . '-'.microtime() . '-'.rand() . "";
|
|
$id = md5($id);
|
|
$lastaccess = time();
|
|
$queryStr = "INSERT INTO `tblSessions` (`id`, `userID`, `lastAccess`, `theme`, `language`, `su`) ".
|
|
"VALUES ('".$id."', ".$data['userid'].", ".$lastaccess.", '".$data['theme']."', '".$data['lang']."', 0)";
|
|
if (!$this->db->getResult($queryStr)) {
|
|
return false;
|
|
}
|
|
$this->id = $id;
|
|
$this->data = $data;
|
|
$this->data['id'] = $id;
|
|
$this->data['lastaccess'] = $lastaccess;
|
|
$this->data['su'] = 0;
|
|
$this->data['clipboard'] = array('docs'=>array(), 'folders'=>array());
|
|
$this->data['clipboard'] = array('type'=>'', 'msg'=>'');
|
|
$this->data['splashmsg'] = array();
|
|
return $id;
|
|
} /* }}} */
|
|
|
|
/**
|
|
* Update last access time of session
|
|
*
|
|
* This function should be called, when the last access time of the
|
|
* session must be updated. This should be done at least after login,
|
|
* but can also be done at any other time. Sessions that are never
|
|
* updated will be deleted when deleteByTime() is called and the session
|
|
* life time has exceeded the cookie life time or 1 week.
|
|
*
|
|
* @param string $id id of session
|
|
* @return boolean true if successful otherwise false
|
|
*/
|
|
function updateAccess($id) { /* {{{ */
|
|
$queryStr = "UPDATE `tblSessions` SET `lastAccess` = " . time() . " WHERE `id` = " . $this->db->qstr($id);
|
|
if (!$this->db->getResult($queryStr))
|
|
return false;
|
|
return true;
|
|
} /* }}} */
|
|
|
|
/**
|
|
* Delete sessions older than a given time from the database
|
|
*
|
|
* @param integer $sec maximum number of seconds a session may live
|
|
* @return boolean true if successful otherwise false
|
|
*/
|
|
function deleteByTime($sec) { /* {{{ */
|
|
$queryStr = "DELETE FROM `tblSessions` WHERE " . time() . " - `lastAccess` > ".$sec;
|
|
if (!$this->db->getResult($queryStr)) {
|
|
return false;
|
|
}
|
|
return true;
|
|
} /* }}} */
|
|
|
|
/**
|
|
* Delete session by its id
|
|
*
|
|
* @param string $id id of session
|
|
* @return boolean true if successful otherwise false
|
|
*/
|
|
function delete($id) { /* {{{ */
|
|
$queryStr = "DELETE FROM `tblSessions` WHERE `id` = " . $this->db->qstr($id);
|
|
if (!$this->db->getResult($queryStr)) {
|
|
return false;
|
|
}
|
|
$this->id = false;
|
|
return true;
|
|
} /* }}} */
|
|
|
|
/**
|
|
* Get session id
|
|
*
|
|
* @return string session id
|
|
*/
|
|
function getId() { /* {{{ */
|
|
return $this->id;
|
|
} /* }}} */
|
|
|
|
/**
|
|
* Get user id of session
|
|
*
|
|
* @return integer user id
|
|
*/
|
|
function getUser() { /* {{{ */
|
|
return $this->data['userid'];
|
|
} /* }}} */
|
|
|
|
/**
|
|
* Set user of session
|
|
*
|
|
* @param integer $userid id of user
|
|
*/
|
|
function setUser($userid) { /* {{{ */
|
|
/* id is only set if load() was called before */
|
|
if($this->id) {
|
|
$queryStr = "UPDATE `tblSessions` SET `userID` = " . $this->db->qstr($userid) . " WHERE `id` = " . $this->db->qstr($this->id);
|
|
if (!$this->db->getResult($queryStr))
|
|
return false;
|
|
$this->data['userid'] = $userid;
|
|
}
|
|
return true;
|
|
} /* }}} */
|
|
|
|
/**
|
|
* Set language of session
|
|
*
|
|
* @param string $lang language
|
|
*/
|
|
function setLanguage($lang) { /* {{{ */
|
|
/* id is only set if load() was called before */
|
|
if($this->id) {
|
|
$queryStr = "UPDATE `tblSessions` SET `language` = " . $this->db->qstr($lang) . " WHERE `id` = " . $this->db->qstr($this->id);
|
|
if (!$this->db->getResult($queryStr))
|
|
return false;
|
|
$this->data['lang'] = $lang;
|
|
}
|
|
return true;
|
|
} /* }}} */
|
|
|
|
/**
|
|
* Get language of session
|
|
*
|
|
* @return string language
|
|
*/
|
|
function getLanguage() { /* {{{ */
|
|
return $this->data['lang'];
|
|
} /* }}} */
|
|
|
|
/**
|
|
* Substitute user of session
|
|
*
|
|
* @param integer $su user id
|
|
*/
|
|
function setSu($su) { /* {{{ */
|
|
/* id is only set if load() was called before */
|
|
if($this->id) {
|
|
$queryStr = "UPDATE `tblSessions` SET `su` = " . (int) $su . " WHERE `id` = " . $this->db->qstr($this->id);
|
|
if (!$this->db->getResult($queryStr))
|
|
return false;
|
|
$this->data['su'] = (int) $su;
|
|
}
|
|
return true;
|
|
} /* }}} */
|
|
|
|
/**
|
|
* Reset substitute user of session
|
|
*
|
|
* @param integer $su user id
|
|
*/
|
|
function resetSu() { /* {{{ */
|
|
/* id is only set if load() was called before */
|
|
if($this->id) {
|
|
$queryStr = "UPDATE `tblSessions` SET `su` = 0 WHERE `id` = " . $this->db->qstr($this->id);
|
|
if (!$this->db->getResult($queryStr))
|
|
return false;
|
|
$this->data['su'] = 0;
|
|
}
|
|
return true;
|
|
} /* }}} */
|
|
|
|
/**
|
|
* Get substituted user id of session
|
|
*
|
|
* @return integer substituted user id
|
|
*/
|
|
function getSu() { /* {{{ */
|
|
return $this->data['su'];
|
|
} /* }}} */
|
|
|
|
/**
|
|
* Set clipboard of session
|
|
*
|
|
* @param array $clipboard list of folders and documents
|
|
*/
|
|
function setClipboard($clipboard) { /* {{{ */
|
|
/* id is only set if load() was called before */
|
|
if($this->id) {
|
|
$queryStr = "UPDATE `tblSessions` SET `clipboard` = " . $this->db->qstr(json_encode($clipboard)) . " WHERE `id` = " . $this->db->qstr($this->id);
|
|
if (!$this->db->getResult($queryStr))
|
|
return false;
|
|
$this->data['clipboard'] = $clipboard;
|
|
}
|
|
return true;
|
|
} /* }}} */
|
|
|
|
/**
|
|
* Get clipboard of session
|
|
*
|
|
* @return array list of clipboard entries
|
|
*/
|
|
function getClipboard() { /* {{{ */
|
|
return (array) $this->data['clipboard'];
|
|
} /* }}} */
|
|
|
|
/**
|
|
* Add to clipboard of session
|
|
*
|
|
* @param object $object Document or folder
|
|
*/
|
|
function addToClipboard($object) { /* {{{ */
|
|
/* id is only set if load() was called before */
|
|
if($this->id) {
|
|
$dms = $object->getDMS();
|
|
if($object->isType('document')) {
|
|
if(!in_array($object->getID(), $this->data['clipboard']['docs']))
|
|
array_push($this->data['clipboard']['docs'], $object->getID());
|
|
} elseif($object->isType('folder')) {
|
|
if(!in_array($object->getID(), $this->data['clipboard']['folders']))
|
|
array_push($this->data['clipboard']['folders'], $object->getID());
|
|
}
|
|
$queryStr = "UPDATE `tblSessions` SET `clipboard` = " . $this->db->qstr(json_encode($this->data['clipboard'])) . " WHERE `id` = " . $this->db->qstr($this->id);
|
|
if (!$this->db->getResult($queryStr))
|
|
return false;
|
|
}
|
|
return true;
|
|
} /* }}} */
|
|
|
|
/**
|
|
* Remove from clipboard
|
|
*
|
|
* @param object $object Document or folder to remove
|
|
*/
|
|
function removeFromClipboard($object) { /* {{{ */
|
|
/* id is only set if load() was called before */
|
|
if($this->id) {
|
|
$dms = $object->getDMS();
|
|
if($object->isType('document')) {
|
|
$key = array_search($object->getID(), $this->data['clipboard']['docs']);
|
|
if($key !== false)
|
|
unset($this->data['clipboard']['docs'][$key]);
|
|
} elseif($object->isType('folder')) {
|
|
$key = array_search($object->getID(), $this->data['clipboard']['folders']);
|
|
if($key !== false)
|
|
unset($this->data['clipboard']['folders'][$key]);
|
|
}
|
|
$queryStr = "UPDATE `tblSessions` SET `clipboard` = " . $this->db->qstr(json_encode($this->data['clipboard'])) . " WHERE `id` = " . $this->db->qstr($this->id);
|
|
if (!$this->db->getResult($queryStr))
|
|
return false;
|
|
}
|
|
return true;
|
|
} /* }}} */
|
|
|
|
/**
|
|
* Clear clipboard
|
|
*
|
|
*/
|
|
function clearClipboard() { /* {{{ */
|
|
$this->data['clipboard']['docs'] = array();
|
|
$this->data['clipboard']['folders'] = array();
|
|
$queryStr = "UPDATE `tblSessions` SET `clipboard` = " . $this->db->qstr(json_encode($this->data['clipboard'])) . " WHERE `id` = " . $this->db->qstr($this->id);
|
|
if (!$this->db->getResult($queryStr))
|
|
return false;
|
|
return true;
|
|
} /* }}} */
|
|
|
|
/**
|
|
* Set splash message of session
|
|
*
|
|
* @param array $msg contains 'typ' and 'msg'
|
|
*/
|
|
function setSplashMsg($msg) { /* {{{ */
|
|
/* id is only set if load() was called before */
|
|
if($this->id) {
|
|
$queryStr = "UPDATE `tblSessions` SET `splashmsg` = " . $this->db->qstr(json_encode($msg)) . " WHERE `id` = " . $this->db->qstr($this->id);
|
|
if (!$this->db->getResult($queryStr))
|
|
return false;
|
|
$this->data['splashmsg'] = $msg;
|
|
}
|
|
return true;
|
|
} /* }}} */
|
|
|
|
/**
|
|
* Set splash message of session
|
|
*
|
|
* @param array $msg contains 'typ' and 'msg'
|
|
*/
|
|
function clearSplashMsg() { /* {{{ */
|
|
/* id is only set if load() was called before */
|
|
if($this->id) {
|
|
$queryStr = "UPDATE `tblSessions` SET `splashmsg` = '' WHERE `id` = " . $this->db->qstr($this->id);
|
|
if (!$this->db->getResult($queryStr))
|
|
return false;
|
|
$this->data['splashmsg'] = '';
|
|
}
|
|
return true;
|
|
} /* }}} */
|
|
|
|
/**
|
|
* Get splash message of session
|
|
*
|
|
* @return array last splash message
|
|
*/
|
|
function getSplashMsg() { /* {{{ */
|
|
return (array) $this->data['splashmsg'];
|
|
} /* }}} */
|
|
|
|
/**
|
|
* Get timestamp of last access
|
|
*
|
|
* @return int last access time
|
|
*/
|
|
function getLastAccess() { /* {{{ */
|
|
return (int) $this->data['lastaccess'];
|
|
} /* }}} */
|
|
|
|
}
|
|
|
|
/**
|
|
* Class for managing sessions
|
|
*
|
|
* This class is for retrieving sessions.
|
|
*
|
|
* @category DMS
|
|
* @package SeedDMS
|
|
* @author Uwe Steinmann <uwe@steinmann.cx>
|
|
* @copyright 2014 Uwe Steinmann
|
|
* @version Release: @package_version@
|
|
*/
|
|
class SeedDMS_SessionMgr {
|
|
/**
|
|
* @var object $db reference to database object. This must be an instance
|
|
* of {@link SeedDMS_Core_DatabaseAccess}.
|
|
* @access protected
|
|
*/
|
|
protected $db;
|
|
|
|
/**
|
|
* Create a new instance of the session manager
|
|
*
|
|
* @param object $db object to access the underlying database
|
|
* @return object instance of SeedDMS_SessionMgr
|
|
*/
|
|
function __construct($db) { /* {{{ */
|
|
$this->db = $db;
|
|
} /* }}} */
|
|
|
|
/**
|
|
* Create a new session and saving the given data into the database
|
|
*
|
|
* @param array $data data saved in session (the only fields supported
|
|
* are userid, theme, language, su)
|
|
* @return string/boolean id of session of false in case of an error
|
|
*/
|
|
function create($data) { /* {{{ */
|
|
$id = "" . rand() . time() . rand() . "";
|
|
$id = md5($id);
|
|
$lastaccess = time();
|
|
$queryStr = "INSERT INTO `tblSessions` (`id`, `userID`, `lastAccess`, `theme`, `language`, `su`) ".
|
|
"VALUES ('".$id."', ".$data['userid'].", ".$lastaccess.", '".$data['theme']."', '".$data['lang']."', 0)";
|
|
if (!$this->db->getResult($queryStr)) {
|
|
return false;
|
|
}
|
|
|
|
return $id;
|
|
} /* }}} */
|
|
|
|
/**
|
|
* Get list of all active sessions
|
|
*
|
|
* @return array list of sessions
|
|
*/
|
|
function getAllSessions() { /* {{{ */
|
|
$queryStr = "SELECT * FROM `tblSessions`";
|
|
$resArr = $this->db->getResultArray($queryStr);
|
|
if (is_bool($resArr) && $resArr == false)
|
|
return false;
|
|
$sessions = array();
|
|
foreach($resArr as $rec) {
|
|
$session = new SeedDMS_Session($this->db);
|
|
$session->load($rec['id']);
|
|
$sessions[] = $session;
|
|
}
|
|
return $sessions;
|
|
|
|
} /* }}} */
|
|
|
|
/**
|
|
* Get list of active sessions for a given user
|
|
*
|
|
* @return array list of sessions
|
|
*/
|
|
function getUserSessions($user, $limit=0) { /* {{{ */
|
|
$queryStr = "SELECT * FROM `tblSessions` WHERE `userID`=".$user->getID();
|
|
$queryStr .= " ORDER BY `lastAccess` DESC";
|
|
if($limit > 0)
|
|
$queryStr .= " LIMIT ".(int) $limit;
|
|
$resArr = $this->db->getResultArray($queryStr);
|
|
if (is_bool($resArr) && $resArr == false)
|
|
return false;
|
|
$sessions = array();
|
|
foreach($resArr as $rec) {
|
|
$session = new SeedDMS_Session($this->db);
|
|
$session->load($rec['id']);
|
|
$sessions[] = $session;
|
|
}
|
|
return $sessions;
|
|
|
|
} /* }}} */
|
|
|
|
/**
|
|
* Get list of active sessions with a given time
|
|
*
|
|
* @return array list of sessions
|
|
*/
|
|
function getLastAccessedSessions($datetime) { /* {{{ */
|
|
if(!$ts = makeTsFromLongDate($datetime))
|
|
return false;
|
|
$queryStr = "SELECT a.* FROM `tblSessions` AS a LEFT OUTER JOIN `tblSessions` AS b ON a.`userID`=b.`userID` AND a.`lastAccess`< b.`lastAccess` WHERE b.`userID` IS NULL AND a.`lastAccess` >=".$ts;
|
|
$resArr = $this->db->getResultArray($queryStr);
|
|
if (is_bool($resArr) && $resArr == false)
|
|
return false;
|
|
$sessions = array();
|
|
foreach($resArr as $rec) {
|
|
$session = new SeedDMS_Session($this->db);
|
|
$session->load($rec['id']);
|
|
$sessions[] = $session;
|
|
}
|
|
return $sessions;
|
|
|
|
} /* }}} */
|
|
}
|