5
* @version $Id: viewonline.php,v 1.126 2007/10/05 14:30:07 acydburn Exp $
6
* @copyright (c) 2005 phpBB Group
7
* @license http://opensource.org/licenses/gpl-license.php GNU Public License
14
define('IN_PHPBB', true);
15
$phpbb_root_path = (defined('PHPBB_ROOT_PATH')) ? PHPBB_ROOT_PATH : './';
16
$phpEx = substr(strrchr(__FILE__, '.'), 1);
17
include($phpbb_root_path . 'common.' . $phpEx);
19
// Start session management
20
$user->session_begin();
21
$auth->acl($user->data);
22
$user->setup('memberlist');
24
// Get and set some variables
25
$mode = request_var('mode', '');
26
$session_id = request_var('s', '');
27
$start = request_var('start', 0);
28
$sort_key = request_var('sk', 'b');
29
$sort_dir = request_var('sd', 'd');
30
$show_guests= ($config['load_online_guests']) ? request_var('sg', 0) : 0;
32
// Can this user view profiles/memberlist?
33
if (!$auth->acl_gets('u_viewprofile', 'a_user', 'a_useradd', 'a_userdel'))
35
if ($user->data['user_id'] != ANONYMOUS)
37
trigger_error('NO_VIEW_USERS');
40
login_box('', $user->lang['LOGIN_EXPLAIN_VIEWONLINE']);
43
$sort_key_text = array('a' => $user->lang['SORT_USERNAME'], 'b' => $user->lang['SORT_JOINED'], 'c' => $user->lang['SORT_LOCATION']);
44
$sort_key_sql = array('a' => 'u.username_clean', 'b' => 's.session_time', 'c' => 's.session_page');
47
if (!isset($sort_key_text[$sort_key]))
52
$order_by = $sort_key_sql[$sort_key] . ' ' . (($sort_dir == 'a') ? 'ASC' : 'DESC');
55
if ($mode == 'whois' && $auth->acl_get('a_') && $session_id)
57
include($phpbb_root_path . 'includes/functions_user.' . $phpEx);
59
$sql = 'SELECT u.user_id, u.username, u.user_type, s.session_ip
60
FROM ' . USERS_TABLE . ' u, ' . SESSIONS_TABLE . " s
61
WHERE s.session_id = '" . $db->sql_escape($session_id) . "'
62
AND u.user_id = s.session_user_id";
63
$result = $db->sql_query($sql);
65
if ($row = $db->sql_fetchrow($result))
67
$template->assign_var('WHOIS', user_ipwhois($row['session_ip']));
69
$db->sql_freeresult($result);
72
page_header($user->lang['WHO_IS_ONLINE']);
74
$template->set_filenames(array(
75
'body' => 'viewonline_whois.html')
77
make_jumpbox(append_sid("{$phpbb_root_path}viewforum.$phpEx"));
83
$sql = 'SELECT forum_id, forum_name, parent_id, forum_type, left_id, right_id
84
FROM ' . FORUMS_TABLE . '
85
ORDER BY left_id ASC';
86
$result = $db->sql_query($sql, 600);
88
$forum_data = array();
89
while ($row = $db->sql_fetchrow($result))
91
$forum_data[$row['forum_id']] = $row;
93
$db->sql_freeresult($result);
97
// Get number of online guests (if we do not display them)
100
switch ($db->sql_layer)
103
$sql = 'SELECT COUNT(session_ip) as num_guests
105
SELECT DISTINCT session_ip
106
FROM ' . SESSIONS_TABLE . '
107
WHERE session_user_id = ' . ANONYMOUS . '
108
AND session_time >= ' . (time() - ($config['load_online_time'] * 60)) .
113
$sql = 'SELECT COUNT(DISTINCT session_ip) as num_guests
114
FROM ' . SESSIONS_TABLE . '
115
WHERE session_user_id = ' . ANONYMOUS . '
116
AND session_time >= ' . (time() - ($config['load_online_time'] * 60));
119
$result = $db->sql_query($sql);
120
$guest_counter = (int) $db->sql_fetchfield('num_guests');
121
$db->sql_freeresult($result);
125
$sql = 'SELECT u.user_id, u.username, u.username_clean, u.user_type, u.user_colour, s.session_id, s.session_time, s.session_page, s.session_ip, s.session_browser, s.session_viewonline
126
FROM ' . USERS_TABLE . ' u, ' . SESSIONS_TABLE . ' s
127
WHERE u.user_id = s.session_user_id
128
AND s.session_time >= ' . (time() - ($config['load_online_time'] * 60)) .
129
((!$show_guests) ? ' AND s.session_user_id <> ' . ANONYMOUS : '') . '
130
ORDER BY ' . $order_by;
131
$result = $db->sql_query($sql);
133
$prev_id = $prev_ip = $user_list = array();
134
$logged_visible_online = $logged_hidden_online = $counter = 0;
136
while ($row = $db->sql_fetchrow($result))
138
if ($row['user_id'] != ANONYMOUS && !isset($prev_id[$row['user_id']]))
140
$view_online = $s_user_hidden = false;
141
$user_colour = ($row['user_colour']) ? ' style="color:#' . $row['user_colour'] . '" class="username-coloured"' : '';
143
$username_full = ($row['user_type'] != USER_IGNORE) ? get_username_string('full', $row['user_id'], $row['username'], $row['user_colour']) : '<span' . $user_colour . '>' . $row['username'] . '</span>';
145
if (!$row['session_viewonline'])
147
$view_online = ($auth->acl_get('u_viewonline')) ? true : false;
148
$logged_hidden_online++;
150
$username_full = '<em>' . $username_full . '</em>';
151
$s_user_hidden = true;
156
$logged_visible_online++;
159
$prev_id[$row['user_id']] = 1;
166
if (!$view_online || $counter > $start + $config['topics_per_page'] || $counter <= $start)
171
else if ($show_guests && $row['user_id'] == ANONYMOUS && !isset($prev_ip[$row['session_ip']]))
173
$prev_ip[$row['session_ip']] = 1;
177
if ($counter > $start + $config['topics_per_page'] || $counter <= $start)
182
$s_user_hidden = false;
183
$username_full = get_username_string('full', $row['user_id'], $user->lang['GUEST']);
190
preg_match('#^([a-z/]+)#i', $row['session_page'], $on_page);
191
if (!sizeof($on_page))
199
$location = $user->lang['INDEX'];
200
$location_url = append_sid("{$phpbb_root_path}index.$phpEx");
204
$location = $user->lang['ACP'];
205
$location_url = append_sid("{$phpbb_root_path}index.$phpEx");
211
preg_match('#_f_=([0-9]+)x#i', $row['session_page'], $forum_id);
212
$forum_id = (sizeof($forum_id)) ? (int) $forum_id[1] : 0;
214
if ($forum_id && $auth->acl_get('f_list', $forum_id))
217
$location_url = append_sid("{$phpbb_root_path}viewforum.$phpEx", 'f=' . $forum_id);
219
if ($forum_data[$forum_id]['forum_type'] == FORUM_LINK)
221
$location = sprintf($user->lang['READING_LINK'], $forum_data[$forum_id]['forum_name']);
228
preg_match('#mode=([a-z]+)#', $row['session_page'], $on_page);
234
$location = sprintf($user->lang['REPLYING_MESSAGE'], $forum_data[$forum_id]['forum_name']);
238
$location = sprintf($user->lang['POSTING_MESSAGE'], $forum_data[$forum_id]['forum_name']);
244
$location = sprintf($user->lang['READING_TOPIC'], $forum_data[$forum_id]['forum_name']);
248
$location = sprintf($user->lang['READING_FORUM'], $forum_data[$forum_id]['forum_name']);
254
$location = $user->lang['INDEX'];
255
$location_url = append_sid("{$phpbb_root_path}index.$phpEx");
260
$location = $user->lang['SEARCHING_FORUMS'];
261
$location_url = append_sid("{$phpbb_root_path}search.$phpEx");
265
$location = $user->lang['VIEWING_FAQ'];
266
$location_url = append_sid("{$phpbb_root_path}faq.$phpEx");
270
$location = $user->lang['VIEWING_ONLINE'];
271
$location_url = append_sid("{$phpbb_root_path}viewonline.$phpEx");
275
$location = (strpos($row['session_page'], 'mode=viewprofile') !== false) ? $user->lang['VIEWING_MEMBER_PROFILE'] : $user->lang['VIEWING_MEMBERS'];
276
$location_url = append_sid("{$phpbb_root_path}memberlist.$phpEx");
280
$location = $user->lang['VIEWING_MCP'];
281
$location_url = append_sid("{$phpbb_root_path}index.$phpEx");
285
$location = $user->lang['VIEWING_UCP'];
287
// Grab some common modules
289
'mode=register' => 'VIEWING_REGISTER',
290
'i=pm&mode=compose' => 'POSTING_PRIVATE_MESSAGE',
291
'i=pm&' => 'VIEWING_PRIVATE_MESSAGES',
292
'i=profile&' => 'CHANGING_PROFILE',
293
'i=prefs&' => 'CHANGING_PREFERENCES',
296
foreach ($url_params as $param => $lang)
298
if (strpos($row['session_page'], $param) !== false)
300
$location = $user->lang[$lang];
305
$location_url = append_sid("{$phpbb_root_path}index.$phpEx");
309
$location = $user->lang['DOWNLOADING_FILE'];
310
$location_url = append_sid("{$phpbb_root_path}index.$phpEx");
314
$location = $user->lang['REPORTING_POST'];
315
$location_url = append_sid("{$phpbb_root_path}index.$phpEx");
319
$location = $user->lang['INDEX'];
320
$location_url = append_sid("{$phpbb_root_path}index.$phpEx");
324
$template->assign_block_vars('user_row', array(
325
'USERNAME' => $row['username'],
326
'USERNAME_COLOUR' => $row['user_colour'],
327
'USERNAME_FULL' => $username_full,
328
'LASTUPDATE' => $user->format_date($row['session_time']),
329
'FORUM_LOCATION' => $location,
330
'USER_IP' => ($auth->acl_get('a_')) ? (($mode == 'lookup' && $session_id == $row['session_id']) ? gethostbyaddr($row['session_ip']) : $row['session_ip']) : '',
331
'USER_BROWSER' => ($auth->acl_get('a_user')) ? $row['session_browser'] : '',
333
'U_USER_PROFILE' => ($row['user_type'] != USER_IGNORE) ? get_username_string('profile', $row['user_id'], '') : '',
334
'U_USER_IP' => append_sid("{$phpbb_root_path}viewonline.$phpEx", 'mode=lookup' . (($mode != 'lookup' || $row['session_id'] != $session_id) ? '&s=' . $row['session_id'] : '') . "&sg=$show_guests&start=$start&sk=$sort_key&sd=$sort_dir"),
335
'U_WHOIS' => append_sid("{$phpbb_root_path}viewonline.$phpEx", 'mode=whois&s=' . $row['session_id']),
336
'U_FORUM_LOCATION' => $location_url,
338
'S_USER_HIDDEN' => $s_user_hidden,
339
'S_GUEST' => ($row['user_id'] == ANONYMOUS) ? true : false,
340
'S_USER_TYPE' => $row['user_type'],
343
$db->sql_freeresult($result);
344
unset($prev_id, $prev_ip);
346
// Generate reg/hidden/guest online text
347
$vars_online = array(
348
'REG' => array('logged_visible_online', 'l_r_user_s'),
349
'HIDDEN'=> array('logged_hidden_online', 'l_h_user_s'),
350
'GUEST' => array('guest_counter', 'l_g_user_s')
353
foreach ($vars_online as $l_prefix => $var_ary)
355
switch ($$var_ary[0])
358
$$var_ary[1] = $user->lang[$l_prefix . '_USERS_ZERO_ONLINE'];
362
$$var_ary[1] = $user->lang[$l_prefix . '_USER_ONLINE'];
366
$$var_ary[1] = $user->lang[$l_prefix . '_USERS_ONLINE'];
372
$pagination = generate_pagination(append_sid("{$phpbb_root_path}viewonline.$phpEx", "sg=$show_guests&sk=$sort_key&sd=$sort_dir"), $counter, $config['topics_per_page'], $start);
374
// Grab group details for legend display
375
if ($auth->acl_gets('a_group', 'a_groupadd', 'a_groupdel'))
377
$sql = 'SELECT group_id, group_name, group_colour, group_type
378
FROM ' . GROUPS_TABLE . '
379
WHERE group_legend = 1
380
ORDER BY group_name ASC';
384
$sql = 'SELECT g.group_id, g.group_name, g.group_colour, g.group_type
385
FROM ' . GROUPS_TABLE . ' g
386
LEFT JOIN ' . USER_GROUP_TABLE . ' ug
388
g.group_id = ug.group_id
389
AND ug.user_id = ' . $user->data['user_id'] . '
390
AND ug.user_pending = 0
392
WHERE g.group_legend = 1
393
AND (g.group_type <> ' . GROUP_HIDDEN . ' OR ug.user_id = ' . $user->data['user_id'] . ')
394
ORDER BY g.group_name ASC';
396
$result = $db->sql_query($sql);
399
while ($row = $db->sql_fetchrow($result))
401
if ($row['group_name'] == 'BOTS')
403
$legend .= (($legend != '') ? ', ' : '') . '<span style="color:#' . $row['group_colour'] . '">' . $user->lang['G_BOTS'] . '</span>';
407
$legend .= (($legend != '') ? ', ' : '') . '<a style="color:#' . $row['group_colour'] . '" href="' . append_sid("{$phpbb_root_path}memberlist.$phpEx", 'mode=group&g=' . $row['group_id']) . '">' . (($row['group_type'] == GROUP_SPECIAL) ? $user->lang['G_' . $row['group_name']] : $row['group_name']) . '</a>';
410
$db->sql_freeresult($result);
412
// Refreshing the page every 60 seconds...
413
meta_refresh(60, append_sid("{$phpbb_root_path}viewonline.$phpEx", "sg=$show_guests&sk=$sort_key&sd=$sort_dir&start=$start"));
415
// Send data to template
416
$template->assign_vars(array(
417
'TOTAL_REGISTERED_USERS_ONLINE' => sprintf($l_r_user_s, $logged_visible_online) . sprintf($l_h_user_s, $logged_hidden_online),
418
'TOTAL_GUEST_USERS_ONLINE' => sprintf($l_g_user_s, $guest_counter),
420
'PAGINATION' => $pagination,
421
'PAGE_NUMBER' => on_page($counter, $config['topics_per_page'], $start),
423
'U_SORT_USERNAME' => append_sid("{$phpbb_root_path}viewonline.$phpEx", 'sk=a&sd=' . (($sort_key == 'a' && $sort_dir == 'a') ? 'd' : 'a') . '&sg=' . ((int) $show_guests)),
424
'U_SORT_UPDATED' => append_sid("{$phpbb_root_path}viewonline.$phpEx", 'sk=b&sd=' . (($sort_key == 'b' && $sort_dir == 'a') ? 'd' : 'a') . '&sg=' . ((int) $show_guests)),
425
'U_SORT_LOCATION' => append_sid("{$phpbb_root_path}viewonline.$phpEx", 'sk=c&sd=' . (($sort_key == 'c' && $sort_dir == 'a') ? 'd' : 'a') . '&sg=' . ((int) $show_guests)),
427
'U_SWITCH_GUEST_DISPLAY' => append_sid("{$phpbb_root_path}viewonline.$phpEx", 'sg=' . ((int) !$show_guests)),
428
'L_SWITCH_GUEST_DISPLAY' => ($show_guests) ? $user->lang['HIDE_GUESTS'] : $user->lang['DISPLAY_GUESTS'],
429
'S_SWITCH_GUEST_DISPLAY' => ($config['load_online_guests']) ? true : false)
432
// We do not need to load the who is online box here. ;)
433
$config['load_online'] = false;
436
page_header($user->lang['WHO_IS_ONLINE']);
438
$template->set_filenames(array(
439
'body' => 'viewonline_body.html')
441
make_jumpbox(append_sid("{$phpbb_root_path}viewforum.$phpEx"));
b'\\ No newline at end of file'