/* the code above is auto generated do not remove the tag below */
###END_AUTOCODE
+ static function logdeb($msg)
+ {
+ if (common_config('sessions', 'debug')) {
+ common_debug("Session: " . $msg);
+ }
+ }
+
static function open($save_path, $session_name)
{
return true;
static function read($id)
{
+ self::logdeb("Fetching session '$id'");
+
$session = Session::staticGet('id', $id);
if (empty($session)) {
static function write($id, $session_data)
{
+ self::logdeb("Writing session '$id'");
+
$session = Session::staticGet('id', $id);
if (empty($session)) {
static function destroy($id)
{
+ self::logdeb("Deleting session $id");
+
$session = Session::staticGet('id', $id);
if (!empty($session)) {
static function gc($maxlifetime)
{
- $epoch = time() - $maxlifetime;
+ self::logdeb("garbage collection (maxlifetime = $maxlifetime)");
- $qry = 'DELETE FROM session ' .
- 'WHERE modified < "'.$epoch.'"';
+ $epoch = common_sql_date(time() - $maxlifetime);
+
+ $ids = array();
$session = new Session();
+ $session->whereAdd('modified < "'.$epoch.'"');
+ $session->selectAdd();
+ $session->selectAdd('id');
+
+ $session->find();
+
+ while ($session->fetch()) {
+ $ids[] = $session->id;
+ }
+
+ $session->free();
- $session->query($qry);
+ foreach ($ids as $id) {
+ self::destroy($id);
+ }
}
static function setSaveHandler()
{
- session_set_save_handler('Session::open', 'Session::close', 'Session::read',
- 'Session::write', 'Session::destroy', 'Session::gc');
+ self::logdeb("setting save handlers");
+ $result = session_set_save_handler('Session::open', 'Session::close', 'Session::read',
+ 'Session::write', 'Session::destroy', 'Session::gc');
+ self::logdeb("save handlers result = $result");
+ return $result;
}
}