mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-03 12:39:25 +01:00
Moved list_sessions and total from admin.socurrentsessions into the session-class and implemented them for php4 too.
So admin.socurrentsessions is no longer used and bocurrentsessions as well as the phpgwapi/templates/xxx/navbar.inc.php use the session-class to get the number of loged-in-users. Aktivated the accesslog f�r php4-sessions too.
This commit is contained in:
parent
3ede0a0aa0
commit
f9c53875eb
@ -20,19 +20,14 @@
|
|||||||
'kill' => True
|
'kill' => True
|
||||||
);
|
);
|
||||||
|
|
||||||
function bocurrentsessions()
|
|
||||||
{
|
|
||||||
$this->so = CreateObject('admin.socurrentsessions');
|
|
||||||
}
|
|
||||||
|
|
||||||
function total()
|
function total()
|
||||||
{
|
{
|
||||||
return $this->so->total();
|
return $GLOBALS['phpgw']->session->total();
|
||||||
}
|
}
|
||||||
|
|
||||||
function list_sessions($start,$order,$sort)
|
function list_sessions($start,$order,$sort)
|
||||||
{
|
{
|
||||||
$values = $this->so->list_sessions($start,$sort,$order);
|
$values = $GLOBALS['phpgw']->session->list_sessions($start,$sort,$order);
|
||||||
|
|
||||||
while (list(,$value) = @each($values))
|
while (list(,$value) = @each($values))
|
||||||
{
|
{
|
||||||
|
@ -1,59 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**************************************************************************\
|
|
||||||
* phpGroupWare - Administration *
|
|
||||||
* http://www.phpgroupware.org *
|
|
||||||
* This file written by Joseph Engo <jengo@phpgroupware.org> *
|
|
||||||
* -------------------------------------------- *
|
|
||||||
* This program is free software; you can redistribute it and/or modify it *
|
|
||||||
* under the terms of the GNU General Public License as published by the *
|
|
||||||
* Free Software Foundation; either version 2 of the License, or (at your *
|
|
||||||
* option) any later version. *
|
|
||||||
\**************************************************************************/
|
|
||||||
|
|
||||||
/* $Id$ */
|
|
||||||
|
|
||||||
class socurrentsessions
|
|
||||||
{
|
|
||||||
var $db;
|
|
||||||
|
|
||||||
function socurrentsessions()
|
|
||||||
{
|
|
||||||
$this->db = $GLOBALS['phpgw']->db;
|
|
||||||
}
|
|
||||||
|
|
||||||
function total()
|
|
||||||
{
|
|
||||||
$this->db->query("select count(*) from phpgw_sessions where session_flags != 'A'",__LINE__,__FILE__);
|
|
||||||
$this->db->next_record();
|
|
||||||
|
|
||||||
return $this->db->f(0);
|
|
||||||
}
|
|
||||||
|
|
||||||
function list_sessions($start,$order,$sort)
|
|
||||||
{
|
|
||||||
switch ($GLOBALS['phpgw_info']['server']['sessions_type'])
|
|
||||||
{
|
|
||||||
case 'php4':
|
|
||||||
/* TODO */
|
|
||||||
break;
|
|
||||||
case 'db':
|
|
||||||
default:
|
|
||||||
$ordermethod = 'order by session_dla asc';
|
|
||||||
$this->db->limit_query("select * from phpgw_sessions where session_flags != 'A' order by $sort $order",$start,__LINE__,__FILE__);
|
|
||||||
|
|
||||||
while ($this->db->next_record())
|
|
||||||
{
|
|
||||||
$values[] = array(
|
|
||||||
'session_id' => $this->db->f('session_id'),
|
|
||||||
'session_lid' => $this->db->f('session_lid'),
|
|
||||||
'session_ip' => $this->db->f('session_ip'),
|
|
||||||
'session_logintime' => $this->db->f('session_logintime'),
|
|
||||||
'session_action' => $this->db->f('session_action'),
|
|
||||||
'session_dla' => $this->db->f('session_dla')
|
|
||||||
);
|
|
||||||
}
|
|
||||||
return $values;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1233,9 +1233,7 @@ if (!@is_file(PHPGW_SERVER_ROOT . '/phpgwapi/templates/' . $GLOBALS['phpgw_info'
|
|||||||
|
|
||||||
if (isset($GLOBALS['phpgw_ifo']['navbar']['admin']) && isset($GLOBALS['phpgw_info']['user']['preferences']['common']['show_currentusers']))
|
if (isset($GLOBALS['phpgw_ifo']['navbar']['admin']) && isset($GLOBALS['phpgw_info']['user']['preferences']['common']['show_currentusers']))
|
||||||
{
|
{
|
||||||
$GLOBALS['phpgw']->db->query('select count(session_id) from phpgw_sessions');
|
$var['current_users'] = lang('Current users') . ': ' . $GLOBALS['phpgw']->session->total();
|
||||||
$GLOBALS['phpgw']->db->next_record();
|
|
||||||
$var['current_users'] = lang('Current users') . ': ' . $GLOBALS['phpgw']->db->f(0);
|
|
||||||
$var['url_current_users'] = $GLOBALS['phpgw']->link('/index.php','menuaction=admin.uicurrentsessions.list_sessions');
|
$var['url_current_users'] = $GLOBALS['phpgw']->link('/index.php','menuaction=admin.uicurrentsessions.list_sessions');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -47,7 +47,9 @@
|
|||||||
var $db2;
|
var $db2;
|
||||||
var $public_functions = array(
|
var $public_functions = array(
|
||||||
'list_methods' => True,
|
'list_methods' => True,
|
||||||
'update_dla' => True
|
'update_dla' => True,
|
||||||
|
'list' => True,
|
||||||
|
'total' => True
|
||||||
);
|
);
|
||||||
|
|
||||||
var $cookie_domain;
|
var $cookie_domain;
|
||||||
@ -1039,5 +1041,38 @@
|
|||||||
/* if no extravars then we return the cleaned up url/scriptname */
|
/* if no extravars then we return the cleaned up url/scriptname */
|
||||||
return $url;
|
return $url;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function list_sessions($start,$order,$sort)
|
||||||
|
{
|
||||||
|
$values = array();
|
||||||
|
|
||||||
|
$ordermethod = 'order by session_dla asc';
|
||||||
|
$this->db->limit_query("select * from phpgw_sessions where session_flags != 'A' order by $sort $order",$start,__LINE__,__FILE__);
|
||||||
|
|
||||||
|
while ($this->db->next_record())
|
||||||
|
{
|
||||||
|
$values[] = array(
|
||||||
|
'session_id' => $this->db->f('session_id'),
|
||||||
|
'session_lid' => $this->db->f('session_lid'),
|
||||||
|
'session_ip' => $this->db->f('session_ip'),
|
||||||
|
'session_logintime' => $this->db->f('session_logintime'),
|
||||||
|
'session_action' => $this->db->f('session_action'),
|
||||||
|
'session_dla' => $this->db->f('session_dla')
|
||||||
|
);
|
||||||
|
}
|
||||||
|
return $values;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
@function total
|
||||||
|
@abstract get number of normal / non-anonymous sessions
|
||||||
|
*/
|
||||||
|
function total()
|
||||||
|
{
|
||||||
|
$this->db->query("select count(*) from phpgw_sessions where session_flags != 'A'",__LINE__,__FILE__);
|
||||||
|
$this->db->next_record();
|
||||||
|
|
||||||
|
return $this->db->f(0);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
?>
|
?>
|
||||||
|
@ -45,7 +45,9 @@
|
|||||||
var $data;
|
var $data;
|
||||||
var $public_functions = array(
|
var $public_functions = array(
|
||||||
'list_methods' => True,
|
'list_methods' => True,
|
||||||
'update_dla' => True
|
'update_dla' => True,
|
||||||
|
'list' => True,
|
||||||
|
'total' => True
|
||||||
);
|
);
|
||||||
|
|
||||||
var $cookie_domain;
|
var $cookie_domain;
|
||||||
@ -59,6 +61,7 @@
|
|||||||
$this->kp3 = get_var('kp3',Array('COOKIE','GET'));
|
$this->kp3 = get_var('kp3',Array('COOKIE','GET'));
|
||||||
/* Create the crypto object */
|
/* Create the crypto object */
|
||||||
$GLOBALS['phpgw']->crypto = CreateObject('phpgwapi.crypto');
|
$GLOBALS['phpgw']->crypto = CreateObject('phpgwapi.crypto');
|
||||||
|
$GLOBALS['phpgw']->datetime = CreateObject('phpgwapi.datetime');
|
||||||
$this->phpgw_set_cookiedomain();
|
$this->phpgw_set_cookiedomain();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -291,23 +294,23 @@
|
|||||||
$parts = explode('.',$dom);
|
$parts = explode('.',$dom);
|
||||||
if (count($parts) > 2)
|
if (count($parts) > 2)
|
||||||
{
|
{
|
||||||
if (!ereg('[0-9]+',$parts[1]))
|
if (!ereg('[0-9]+',$parts[1]))
|
||||||
{
|
{
|
||||||
for($i=1;$i<count($parts);$i++)
|
for($i=1;$i<count($parts);$i++)
|
||||||
{
|
{
|
||||||
$this->cookie_domain .= '.'.$parts[$i];
|
$this->cookie_domain .= '.'.$parts[$i];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
$this->cookie_domain = '';
|
$this->cookie_domain = '';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
$this->cookie_domain = '';
|
$this->cookie_domain = '';
|
||||||
}
|
}
|
||||||
print_debug('COOKIE_DOMAIN',$this->cookie_domain,'api');
|
print_debug('COOKIE_DOMAIN',$this->cookie_domain,'api');
|
||||||
session_set_cookie_params(0,'/',$this->cookie_domain);
|
session_set_cookie_params(0,'/',$this->cookie_domain);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -442,8 +445,8 @@
|
|||||||
session_register('phpgw_session');
|
session_register('phpgw_session');
|
||||||
$GLOBALS['HTTP_SESSION_VARS']['phpgw_session'] = $GLOBALS['phpgw_session'];
|
$GLOBALS['HTTP_SESSION_VARS']['phpgw_session'] = $GLOBALS['phpgw_session'];
|
||||||
|
|
||||||
//$GLOBALS['phpgw']->db->query('INSERT INTO phpgw_access_log(sessionid,loginid,ip,li,lo,account_id) '
|
$GLOBALS['phpgw']->db->query('INSERT INTO phpgw_access_log(sessionid,loginid,ip,li,lo,account_id) '
|
||||||
// ." VALUES ('" . $this->sessionid . "','" . "$login','" . $user_ip . "',".$now.",''," . $this->account_id . ")",__LINE__,__FILE__);
|
." VALUES ('" . $this->sessionid . "','" . "$login','" . $user_ip . "',".$now.",''," . $this->account_id . ")",__LINE__,__FILE__);
|
||||||
|
|
||||||
$this->appsession('account_previous_login','phpgwapi',$GLOBALS['phpgw']->auth->previous_login);
|
$this->appsession('account_previous_login','phpgwapi',$GLOBALS['phpgw']->auth->previous_login);
|
||||||
$GLOBALS['phpgw']->auth->update_lastlogin($this->account_id,$user_ip);
|
$GLOBALS['phpgw']->auth->update_lastlogin($this->account_id,$user_ip);
|
||||||
@ -655,8 +658,8 @@
|
|||||||
session_register('phpgw_session');
|
session_register('phpgw_session');
|
||||||
$GLOBALS['HTTP_SESSION_VARS']['phpgw_session'] = $GLOBALS['phpgw_session'];
|
$GLOBALS['HTTP_SESSION_VARS']['phpgw_session'] = $GLOBALS['phpgw_session'];
|
||||||
|
|
||||||
//$GLOBALS['phpgw']->db->query("INSERT INTO phpgw_access_log VALUES ('" . $this->sessionid . "','"
|
$GLOBALS['phpgw']->db->query("INSERT INTO phpgw_access_log VALUES ('" . $this->sessionid . "','"
|
||||||
// . "$login','" . $user_ip . "','$now','','" . $this->account_id . "')",__LINE__,__FILE__);
|
. "$login','" . $user_ip . "','$now','','" . $this->account_id . "')",__LINE__,__FILE__);
|
||||||
|
|
||||||
$this->appsession('account_previous_login','phpgwapi',$GLOBALS['phpgw']->auth->previous_login);
|
$this->appsession('account_previous_login','phpgwapi',$GLOBALS['phpgw']->auth->previous_login);
|
||||||
$GLOBALS['phpgw']->auth->update_lastlogin($this->account_id,$user_ip);
|
$GLOBALS['phpgw']->auth->update_lastlogin($this->account_id,$user_ip);
|
||||||
@ -693,18 +696,28 @@
|
|||||||
return False;
|
return False;
|
||||||
}
|
}
|
||||||
|
|
||||||
session_unset();
|
$GLOBALS['phpgw']->db->query("UPDATE phpgw_access_log SET lo='" . $GLOBALS['phpgw']->datetime->gmtnow . "' WHERE sessionid='"
|
||||||
session_destroy();
|
. $sessionid . "'",__LINE__,__FILE__);
|
||||||
$this->phpgw_setcookie(session_name());
|
$GLOBALS['phpgw']->db->transaction_commit();
|
||||||
//$GLOBALS['phpgw']->db->query("UPDATE phpgw_access_log SET lo='" . time() . "' WHERE sessionid='"
|
|
||||||
// . $sessionid . "'",__LINE__,__FILE__);
|
|
||||||
|
|
||||||
// Only do the following, if where working with the current user
|
// Only do the following, if where working with the current user
|
||||||
if ($sessionid == $GLOBALS['phpgw_info']['user']['sessionid'])
|
if ($sessionid == $GLOBALS['phpgw_info']['user']['sessionid'])
|
||||||
{
|
{
|
||||||
$this->clean_sessions();
|
$this->clean_sessions();
|
||||||
|
session_unset();
|
||||||
|
session_destroy();
|
||||||
|
$this->phpgw_setcookie(session_name());
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$sessions = $this->list_sessions(0,'','',True);
|
||||||
|
|
||||||
|
if (isset($sessions[$sessionid]))
|
||||||
|
{
|
||||||
|
//echo "<p>session_php4::destroy($session_id): unlink('".$sessions[$sessionid]['php_session_file'].")</p>\n";
|
||||||
|
unlink($sessions[$sessionid]['php_session_file']);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
$GLOBALS['phpgw']->db->transaction_commit();
|
|
||||||
|
|
||||||
return True;
|
return True;
|
||||||
}
|
}
|
||||||
@ -996,4 +1009,85 @@
|
|||||||
/* if no extravars then we return the cleaned up url/scriptname */
|
/* if no extravars then we return the cleaned up url/scriptname */
|
||||||
return $url;
|
return $url;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function session_sort($a,$b)
|
||||||
|
{
|
||||||
|
$sign = strcasecmp($GLOBALS['phpgw']->session->sort_order,'ASC') ? 1 : -1;
|
||||||
|
|
||||||
|
return strcasecmp($a[$GLOBALS['phpgw']->session->sort_by],
|
||||||
|
$b[$GLOBALS['phpgw']->session->sort_by]) * $sign;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
@function list_sessions
|
||||||
|
@abstract get list of normal / non-anonymous sessions
|
||||||
|
@author ralfbecker
|
||||||
|
*/
|
||||||
|
function list_sessions($start,$order,$sort,$all_no_sort = False)
|
||||||
|
{
|
||||||
|
//echo "<p>session_php4::list_sessions($start,'$order','$sort',$all)</p>\n";
|
||||||
|
$values = array();
|
||||||
|
$maxmatchs = $GLOBALS['phpgw_info']['user']['preferences']['common']['maxmatchs'];
|
||||||
|
$dir = opendir($path = ini_get('session.save_path'));
|
||||||
|
while ($file = readdir($dir))
|
||||||
|
{
|
||||||
|
if (substr($file,0,5) != 'sess_')
|
||||||
|
{
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
list($session) = file($path . '/' . $file);
|
||||||
|
|
||||||
|
if (substr($session,0,14) != 'phpgw_session|')
|
||||||
|
{
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
$session = unserialize(substr($session,14));
|
||||||
|
list(,$domain) = explode('@',$session['session_lid']);
|
||||||
|
if (empty($domain))
|
||||||
|
{
|
||||||
|
$domain = $GLOBALS['phpgw_info']['server']['default_domain'];
|
||||||
|
}
|
||||||
|
if ($session['session_flags'] == 'A' || $domain != $this->account_domain || !$session['session_id'])
|
||||||
|
{
|
||||||
|
continue; // no anonymous sessions or other domains
|
||||||
|
}
|
||||||
|
unset($session['phpgw_app_sessions']); // not needed, saves memory
|
||||||
|
//echo "file='$file'=<pre>"; print_r($session); echo "</pre>";
|
||||||
|
|
||||||
|
$session['php_session_file'] = $path . '/' . $file;
|
||||||
|
$values[$session['session_id']] = $session;
|
||||||
|
}
|
||||||
|
closedir($dir);
|
||||||
|
|
||||||
|
if (!$all_no_sort)
|
||||||
|
{
|
||||||
|
$GLOBALS['phpgw']->session->sort_by = $sort;
|
||||||
|
$GLOBALS['phpgw']->session->sort_order = $order;
|
||||||
|
|
||||||
|
uasort($values,array('sessions','session_sort'));
|
||||||
|
|
||||||
|
$i = 0;
|
||||||
|
$start = intval($start);
|
||||||
|
foreach($values as $id => $data)
|
||||||
|
{
|
||||||
|
if ($i < $start || $i > $start+$maxmatchs)
|
||||||
|
{
|
||||||
|
unset($values[$id]);
|
||||||
|
}
|
||||||
|
++$i;
|
||||||
|
}
|
||||||
|
reset($values);
|
||||||
|
}
|
||||||
|
return $values;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
@function total
|
||||||
|
@abstract get number of normal / non-anonymous sessions
|
||||||
|
@author ralfbecker
|
||||||
|
*/
|
||||||
|
function total()
|
||||||
|
{
|
||||||
|
return count($this->list_sessions(0,'','',True));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user