mirror of
https://github.com/phpbb/phpbb.git
synced 2025-02-13 12:35:06 +01:00
- optimized viewtopic.php a little bit - removed the create_function (was consuming too much memory) from viewtopic - check for manually added convert[.exe] program name to imagemagick path in admin_attachments - reduced filesize checking for imagemagick program (some installations require less than 20k) - added checked="checked" for "not selected" topic icon - moved parse_text_display function from functions_posting.php to functions.php (see comment above function) - check for user_id != ANONYMOUS in page_footer for displaying the administration link (there seems to be a problem checking for global options) - rewrote attachment thumbnail functions - utilize GD2 functions if available, more uptodate checks... - changed final thumbnail size calculation - define S_ROW_COUNT within template class itself - added SID to template vars in page_header - added ability to view topic/forum within admin_viewlogs - added optional acl checking to make_jumpbox, no need to duplicate the function for this small need - added custom body file for confirm_box git-svn-id: file:///svn/phpbb/trunk@4920 89ea8834-ac86-4346-8a33-228a782c2dd0
305 lines
8.6 KiB
PHP
305 lines
8.6 KiB
PHP
<?php
|
|
// -------------------------------------------------------------
|
|
//
|
|
// $Id$
|
|
//
|
|
// FILENAME : viewonline.php
|
|
// STARTED : Sat Dec 16, 2000
|
|
// COPYRIGHT : © 2001, 2003 phpBB Group
|
|
// WWW : http://www.phpbb.com/
|
|
// LICENCE : GPL vs2.0 [ see /docs/COPYING ]
|
|
//
|
|
// -------------------------------------------------------------
|
|
|
|
define('IN_PHPBB', true);
|
|
$phpbb_root_path = './';
|
|
$phpEx = substr(strrchr(__FILE__, '.'), 1);
|
|
include($phpbb_root_path . 'common.'.$phpEx);
|
|
|
|
// Start session management
|
|
$user->start();
|
|
$auth->acl($user->data);
|
|
$user->setup();
|
|
|
|
// Get and set some variables
|
|
$mode = request_var('mode', '');
|
|
$session_id = request_var('s', '');
|
|
$start = request_var('start', 0);
|
|
$sort_key = request_var('sk', 'b');
|
|
$sort_dir = request_var('sd', 'd');
|
|
|
|
$sort_key_text = array('a' => $user->lang['SORT_USERNAME'], 'b' => $user->lang['SORT_LOCATION'], 'c' => $user->lang['SORT_JOINED']);
|
|
$sort_key_sql = array('a' => 'username', 'b' => 'session_time', 'c' => 'session_page');
|
|
|
|
// Sorting and order
|
|
$order_by = $sort_key_sql[$sort_key] . ' ' . (($sort_dir == 'a') ? 'ASC' : 'DESC');
|
|
|
|
// Whois requested
|
|
if ($mode == 'whois')
|
|
{
|
|
include($phpbb_root_path.'includes/functions_user.'.$phpEx);
|
|
|
|
$sql = 'SELECT u.user_id, u.username, u.user_type, s.session_ip
|
|
FROM ' . USERS_TABLE . ' u, ' . SESSIONS_TABLE . " s
|
|
WHERE s.session_id = '$session_id'
|
|
AND u.user_id = s.session_user_id";
|
|
$result = $db->sql_query($sql);
|
|
|
|
if ($row = $db->sql_fetchrow($result))
|
|
{
|
|
$whois = user_ipwhois($row['session_ip']);
|
|
|
|
$whois = preg_replace('#(\s+?)([\w\-\._\+]+?@[\w\-\.]+?)(\s+?)#s', '\1<a href="mailto:\2">\2</a>\3', $whois);
|
|
$whois = preg_replace('#(\s+?)(http://.*?)(\s+?)#s', '\1<a href="\2" target="_blank">\2</a>\3', $whois);
|
|
|
|
$template->assign_vars(array(
|
|
'WHOIS' => trim($whois))
|
|
);
|
|
}
|
|
$db->sql_freeresult($result);
|
|
|
|
// Output the page
|
|
page_header($user->lang['WHO_IS_ONLINE']);
|
|
|
|
$template->set_filenames(array(
|
|
'body' => 'viewonline_whois.html')
|
|
);
|
|
make_jumpbox('viewforum.'.$phpEx);
|
|
|
|
page_footer();
|
|
}
|
|
|
|
// Forum info
|
|
$sql = 'SELECT forum_id, forum_name, parent_id, forum_type, left_id, right_id
|
|
FROM ' . FORUMS_TABLE . '
|
|
ORDER BY left_id ASC';
|
|
$result = $db->sql_query($sql, 600);
|
|
|
|
while ($row = $db->sql_fetchrow($result))
|
|
{
|
|
$forum_data[$row['forum_id']] = $row['forum_name'];
|
|
}
|
|
$db->sql_freeresult($result);
|
|
|
|
|
|
// Get user list
|
|
$sql = 'SELECT u.user_id, u.username, u.user_type, u.user_allow_viewonline, u.user_colour, s.session_id, s.session_time, s.session_page, s.session_ip, s.session_allow_viewonline
|
|
FROM ' . USERS_TABLE . ' u, ' . SESSIONS_TABLE . ' s
|
|
WHERE u.user_id = s.session_user_id
|
|
AND s.session_time >= ' . (time() - ($config['load_online_time'] * 60)) . '
|
|
ORDER BY ' . $order_by;
|
|
$result = $db->sql_query($sql);
|
|
|
|
$prev_ip = $prev_id = array();
|
|
$logged_visible_online = $logged_hidden_online = $guests_online = $reg_counter = $guest_counter = 0;
|
|
while ($row = $db->sql_fetchrow($result))
|
|
{
|
|
$view_online = false;
|
|
|
|
if ($row['user_id'] != ANONYMOUS && !in_array($row['user_id'], $prev_id))
|
|
{
|
|
$username = $row['username'];
|
|
|
|
if ($row['user_colour'])
|
|
{
|
|
$username = '<b style="color:#' . $row['user_colour'] . '">' . $username . '</b>';
|
|
}
|
|
|
|
if (!$row['user_allow_viewonline'] || !$row['session_allow_viewonline'])
|
|
{
|
|
$view_online = ($auth->acl_gets('u_viewonline')) ? true : false;
|
|
$logged_hidden_online++;
|
|
|
|
$username = '<i>' . $username . '</i>';
|
|
}
|
|
else
|
|
{
|
|
$view_online = true;
|
|
$logged_visible_online++;
|
|
}
|
|
|
|
$which_counter = 'reg_counter';
|
|
$which_row = 'reg_user_row';
|
|
$prev_id[] = $row['user_id'];
|
|
}
|
|
else if (!in_array($row['session_ip'], $prev_ip))
|
|
{
|
|
$username = $user->lang['GUEST'];
|
|
$view_online = true;
|
|
$guests_online++;
|
|
|
|
$which_counter = 'guest_counter';
|
|
$which_row = 'guest_user_row';
|
|
}
|
|
|
|
$prev_ip[] = $row['session_ip'];
|
|
|
|
if ($view_online)
|
|
{
|
|
preg_match('#^([a-z]+)#i', $row['session_page'], $on_page);
|
|
|
|
switch ($on_page[1])
|
|
{
|
|
case 'index':
|
|
$location = $user->lang['INDEX'];
|
|
$location_url = "index.$phpEx$SID";
|
|
break;
|
|
|
|
case 'posting':
|
|
case 'viewforum':
|
|
case 'viewtopic':
|
|
preg_match('#f=([0-9]+)#', $row['session_page'], $forum_id);
|
|
$forum_id = $forum_id[1];
|
|
|
|
if ($auth->acl_get('f_list', $forum_id))
|
|
{
|
|
$location = '';
|
|
switch ($on_page[1])
|
|
{
|
|
case 'posting':
|
|
preg_match('#mode=([a-z]+)#', $row['session_page'], $on_page);
|
|
|
|
switch ($on_page[1])
|
|
{
|
|
case 'reply':
|
|
$location = sprintf($user->lang['REPLYING_MESSAGE'], $forum_data[$forum_id]);
|
|
break;
|
|
default:
|
|
$location = sprintf($user->lang['POSTING_MESSAGE'], $forum_data[$forum_id]);
|
|
break;
|
|
}
|
|
break;
|
|
|
|
case 'viewtopic':
|
|
$location = sprintf($user->lang['READING_TOPIC'], $forum_data[$forum_id]);
|
|
break;
|
|
|
|
case 'viewforum':
|
|
$location .= sprintf($user->lang['READING_FORUM'], $forum_data[$forum_id]);
|
|
break;
|
|
}
|
|
|
|
$location_url = "viewforum.$phpEx$SID&f=$forum_id";
|
|
}
|
|
else
|
|
{
|
|
$location = $user->lang['INDEX'];
|
|
$location_url = "index.$phpEx$SID";
|
|
}
|
|
break;
|
|
|
|
case 'search':
|
|
$location = $user->lang['SEARCHING_FORUMS'];
|
|
$location_url = "search.$phpEx$SID";
|
|
break;
|
|
|
|
case 'faq':
|
|
$location = $user->lang['VIEWING_FAQ'];
|
|
$location_url = "faq.$phpEx$SID";
|
|
break;
|
|
|
|
case 'viewonline':
|
|
$location = $user->lang['VIEWING_ONLINE'];
|
|
$location_url = "viewonline.$phpEx$SID";
|
|
break;
|
|
|
|
case 'memberslist':
|
|
$location = $user->lang['VIEWING_MEMBERS'];
|
|
$location_url = "memberlist.$phpEx$SID";
|
|
break;
|
|
|
|
case 'ucp':
|
|
$location = $user->lang['VIEWING_UCP'];
|
|
$location_url = '';
|
|
|
|
default:
|
|
$location = $user->lang['INDEX'];
|
|
$location_url = "index.$phpEx$SID";
|
|
break;
|
|
}
|
|
|
|
$template->assign_block_vars($which_row, array(
|
|
'USERNAME' => $username,
|
|
'LASTUPDATE' => $user->format_date($row['session_time']),
|
|
'FORUM_LOCATION'=> $location,
|
|
'USER_IP' => ($auth->acl_get('a_')) ? (($mode == 'lookup' && $session_id == $row['session_id']) ? gethostbyaddr($row['session_ip']) : $row['session_ip']) : '',
|
|
|
|
'U_USER_PROFILE' => ($row['user_type'] <> USER_IGNORE) ? "memberlist.$phpEx$SID&mode=viewprofile&u=" . $row['user_id'] : '',
|
|
'U_USER_IP' => "viewonline.$phpEx$SID" . (($mode != 'lookup' || $row['session_id'] != $session_id) ? '&mode=lookup&s=' . $row['session_id'] : ''),
|
|
'U_WHOIS' => "viewonline.$phpEx$SID&mode=whois&s=" . $row['session_id'],
|
|
'U_FORUM_LOCATION' => $location_url)
|
|
);
|
|
|
|
$$which_counter++;
|
|
}
|
|
}
|
|
$db->sql_freeresult($result);
|
|
unset($prev_id);
|
|
unset($prev_ip);
|
|
|
|
|
|
// Generate reg/hidden/guest online text
|
|
$vars_online = array(
|
|
'REG' => array('logged_visible_online', 'l_r_user_s'),
|
|
'HIDDEN'=> array('logged_hidden_online', 'l_h_user_s'),
|
|
'GUEST' => array('guests_online', 'l_g_user_s')
|
|
);
|
|
|
|
foreach ($vars_online as $l_prefix => $var_ary)
|
|
{
|
|
switch ($$var_ary[0])
|
|
{
|
|
case 0:
|
|
$$var_ary[1] = $user->lang[$l_prefix . '_USERS_ZERO_ONLINE'];
|
|
break;
|
|
|
|
case 1:
|
|
$$var_ary[1] = $user->lang[$l_prefix . '_USER_ONLINE'];
|
|
break;
|
|
|
|
default:
|
|
$$var_ary[1] = $user->lang[$l_prefix . '_USERS_ONLINE'];
|
|
break;
|
|
}
|
|
}
|
|
unset($vars_online);
|
|
|
|
|
|
// Grab group details for legend display
|
|
$sql = 'SELECT group_name, group_colour, group_type
|
|
FROM ' . GROUPS_TABLE . "
|
|
WHERE group_colour <> ''
|
|
AND group_type NOT IN (" . GROUP_HIDDEN . ', ' . GROUP_SPECIAL . ')';
|
|
$result = $db->sql_query($sql);
|
|
|
|
$legend = '';
|
|
while ($row = $db->sql_fetchrow($result))
|
|
{
|
|
$legend .= (($legend != '') ? ', ' : '') . '<span style="color:#' . $row['group_colour'] . '">' . (($row['group_type'] == GROUP_SPECIAL) ? $user->lang['G_' . $row['group_name']] : $row['group_name']) . '</span>';
|
|
}
|
|
$db->sql_freeresult($result);
|
|
|
|
|
|
// Send data to template
|
|
$template->assign_vars(array(
|
|
'TOTAL_REGISTERED_USERS_ONLINE' => sprintf($l_r_user_s, $logged_visible_online) . sprintf($l_h_user_s, $logged_hidden_online),
|
|
'TOTAL_GUEST_USERS_ONLINE' => sprintf($l_g_user_s, $guests_online),
|
|
'LEGEND' => $legend,
|
|
'META' => '<meta http-equiv="refresh" content="60; url=viewonline.' . $phpEx . $SID . '">',
|
|
|
|
'U_SORT_USERNAME' => "viewonline.$phpEx$SID&sk=a&sd=" . (($sort_key == 'a' && $sort_dir == 'a') ? 'd' : 'a'),
|
|
'U_SORT_UPDATED' => "viewonline.$phpEx$SID&sk=b&sd=" . (($sort_key == 'b' && $sort_dir == 'a') ? 'd' : 'a'),
|
|
'U_SORT_LOCATION' => "viewonline.$phpEx$SID&sk=c&sd=" . (($sort_key == 'c' && $sort_dir == 'a') ? 'd' : 'a'))
|
|
);
|
|
|
|
// Output the page
|
|
page_header($user->lang['WHO_IS_ONLINE']);
|
|
|
|
$template->set_filenames(array(
|
|
'body' => 'viewonline_body.html')
|
|
);
|
|
make_jumpbox('viewforum.'.$phpEx);
|
|
|
|
page_footer();
|
|
|
|
?>
|