diff --git a/phpBB/includes/constants.php b/phpBB/includes/constants.php index 4d9dc0798f..2c664542d9 100644 --- a/phpBB/includes/constants.php +++ b/phpBB/includes/constants.php @@ -124,6 +124,7 @@ define(PAGE_TOPIC_OFFSET, 5000); // Auth settings +define(AUTH_LIST_ALL, 0); define(AUTH_ALL, 0); define(AUTH_REG, 1); @@ -145,8 +146,6 @@ define(AUTH_POLLCREATE, 9); define(AUTH_VOTE, 10); define(AUTH_ATTACH, 11); -define(AUTH_LIST_ALL, 20); - // Table names define('AUTH_ACCESS_TABLE', $table_prefix.'auth_access'); diff --git a/phpBB/language/lang_english/lang_main.php b/phpBB/language/lang_english/lang_main.php index 6e9efae22b..e2ed9fac16 100644 --- a/phpBB/language/lang_english/lang_main.php +++ b/phpBB/language/lang_english/lang_main.php @@ -26,12 +26,16 @@ // // You should also try to set a locale and a character // encoding (plus direction). The encoding and direction -// will be sent to the template +// will be sent to the template. The locale may or may +// not work, it's dependent on OS support and the syntax +// varies ... give it your best guess! // setlocale(LC_ALL, "en"); $lang['ENCODING'] = "iso-8859-1"; $lang['DIRECTION'] = "LTR"; +$lang['LEFT'] = "LEFT"; +$lang['RIGHT'] = "RIGHT"; // // Common, these terms are used @@ -193,15 +197,15 @@ $lang['View_newest_posts'] = "View posts since your last visit"; $lang['Topics_marked_read'] = "The topics for this forum have now been marked read"; $lang['Rules_post_can'] = "You can post new topics in this forum"; -$lang['Rules_post_cannot'] = "You can post new topics in this forum"; +$lang['Rules_post_cannot'] = "You cannot post new topics in this forum"; $lang['Rules_reply_can'] = "You can reply to topics in this forum"; -$lang['Rules_reply_cannot'] = "You can reply to topics in this forum"; +$lang['Rules_reply_cannot'] = "You cannot reply to topics in this forum"; $lang['Rules_edit_can'] = "You can edit your posts in this forum"; -$lang['Rules_edit_cannot'] = "You can edit your posts in this forum"; +$lang['Rules_edit_cannot'] = "You cannot edit your posts in this forum"; $lang['Rules_delete_can'] = "You can delete posts in this forum"; -$lang['Rules_delete_cannot'] = "You can delete posts in this forum"; +$lang['Rules_delete_cannot'] = "You cannot delete posts in this forum"; $lang['Rules_vote_can'] = "You can vote in polls in this forum"; -$lang['Rules_vote_cannot'] = "You can vote in polls in this forum"; +$lang['Rules_vote_cannot'] = "You cannot vote in polls in this forum"; $lang['Rules_moderate'] = "You can %smoderate this forum%s"; // %s replaced by a href // @@ -639,6 +643,9 @@ $lang['this_forum'] = " this forum"; // Viewonline // $lang['Who_is_online'] = "Who is online"; +$lang['Reg_users_online'] = "There are %d Registered and %d Hidden users online"; +$lang['Guest_users_online'] = "There are %d Guest users online"; +$lang['Guest_user_online'] = "There is %d Guest user online"; $lang['Online_explain'] = "This data is based on users active over the past five minutes"; $lang['No_users_browsing'] = "There are no users currently browsing this forum"; $lang['Location'] = "Location"; diff --git a/phpBB/viewforum.php b/phpBB/viewforum.php index 592143bdb2..0970521794 100644 --- a/phpBB/viewforum.php +++ b/phpBB/viewforum.php @@ -546,7 +546,7 @@ if($total_topics) $view_topic_url = append_sid("viewtopic.$phpEx?" . POST_TOPIC_URL . "=$topic_id"); $topic_poster = ( $topic_rowset[$i]['user_id'] != ANONYMOUS ) ? "" : ""; - $topic_poster .= $topic_rowset[$i]['username']; + $topic_poster .= ( $topic_rowset[$i]['user_id'] != ANONYMOUS ) ? $topic_rowset[$i]['username'] : $topic_rowset[$i]['post_username']; $topic_poster .= ( $topic_rowset[$i]['user_id'] != ANONYMOUS ) ? "" : ""; $last_post_time = create_date($board_config['default_dateformat'], $topic_rowset[$i]['post_time'], $board_config['board_timezone']); diff --git a/phpBB/viewonline.php b/phpBB/viewonline.php index 3a0fc92ac6..e63a7ee2de 100644 --- a/phpBB/viewonline.php +++ b/phpBB/viewonline.php @@ -33,6 +33,24 @@ init_userprefs($userdata); // End session management // +// --------------- +// Begin functions +// +function inarray($needle, $haystack) +{ + for($i = 0; $i < sizeof($haystack); $i++ ) + { + if( $haystack[$i] == $needle ) + { + return true; + } + } + return false; +} +// +// End functions +// ------------- + // // Output page header and load // viewonline template @@ -72,7 +90,7 @@ if(!$result = $db->sql_query($sql)) } $onlinerow_reg = $db->sql_fetchrowset($result); -$sql = "SELECT session_page, session_logged_in, session_time +$sql = "SELECT session_page, session_logged_in, session_time, session_ip FROM " . SESSIONS_TABLE . " WHERE session_logged_in = 0 AND session_time >= " . ( time() - 300 ) . " @@ -108,9 +126,17 @@ $template->assign_vars(array( $active_users = 0; $guest_users = 0; +// +// Get auth data +// +$is_auth_ary = array(); +$is_auth_ary = auth(AUTH_VIEW, AUTH_LIST_ALL, $userdata); + // // Registered users ... // +$reg_userid_ary = array(); + if( count($onlinerow_reg) ) { $registered_users = 0; @@ -120,26 +146,22 @@ if( count($onlinerow_reg) ) for($i = 0; $i < count($onlinerow_reg); $i++) { - if( !eregi("," . $onlinerow_reg[$i]['user_id'], $displayed_userid_list) ) + if( !inarray($onlinerow_reg[$i]['user_id'], $reg_userid_ary) ) { if( $onlinerow_reg[$i]['user_allow_viewonline'] || $userdata['user_level'] == ADMIN ) { - $displayed_userid_list .= "," . $onlinerow_reg[$i]['user_id']; - $username = $onlinerow_reg[$i]['username']; $hidden = FALSE; $registered_users++; } else { - $displayed_userid_list .= "," . $onlinerow_reg[$i]['user_id']; - $username = $onlinerow_reg[$i]['username']; $hidden = TRUE; $hidden_users++; } - if($onlinerow_reg[$i]['session_page'] < 1) + if( $onlinerow_reg[$i]['session_page'] < 1 || !$is_auth_ary[$onlinerow_reg[$i]['session_page']]['auth_view'] ) { switch($onlinerow_reg[$i]['session_page']) { @@ -209,19 +231,15 @@ if( count($onlinerow_reg) ) } } - $l_h_user_s = ($hidden_users == 1) ? $lang['User'] : $lang['Users']; - $l_r_user_s = ($registered_users == 1) ? $lang['User'] : $lang['Users']; - $l_is_are = ($registered_users == 1) ? $lang['is'] : $lang['are']; - $template->assign_vars(array( - "TOTAL_REGISTERED_USERS_ONLINE" => $lang['There'] . " $l_is_are $logged_visible_online " . $lang['Registered'] . " $l_r_user_s " . $lang['and'] . " $logged_hidden_online " . $lang['Hidden'] . " $l_h_user_s " . $lang['online']) + "TOTAL_REGISTERED_USERS_ONLINE" => sprintf($lang['Reg_users_online'], $registered_users, $hidden_users)) ); } else { $template->assign_vars(array( - "TOTAL_REGISTERED_USERS_ONLINE" => $lang['There'] . " " . $lang['are'] . " 0 " . $lang['Registered'] . " " . $lang['Users'] . " " . $lang['and'] . " 0 " . $lang['Hidden'] . " " . $lang['Users'] . " " . $lang['online'], + "TOTAL_REGISTERED_USERS_ONLINE" => sprintf($lang['Reg_users_online'], 0, 0), "L_NO_REGISTERED_USERS_BROWSING" => $lang['No_users_browsing']) ); } @@ -229,92 +247,96 @@ else // // Guest users // +$guest_userip_ary = array(); + if( count($onlinerow_guest) ) { $guest_users = 0; for($i = 0; $i < count($onlinerow_guest); $i++) { - $guest_users++; - - if($onlinerow_guest[$i]['session_page'] < 1) + if( !inarray($onlinerow_guest[$i]['session_ip'], $guest_userip_ary) ) { - switch($onlinerow_guest[$i]['session_page']) + $guest_users++; + + if($onlinerow_guest[$i]['session_page'] < 1 || !$is_auth_ary[$onlinerow_reg[$i]['session_page']]['auth_view'] ) { - case PAGE_INDEX: - $location = $lang['Forum_index']; - $location_url = "index.$phpEx"; - break; - case PAGE_POSTING: - $location = $lang['Posting_message']; - $location_url = "index.$phpEx"; - break; - case PAGE_LOGIN: - $location = $lang['Logging_on']; - $location_url = "index.$phpEx"; - break; - case PAGE_SEARCH: - $location = $lang['Searching_forums']; - $location_url = "search.$phpEx"; - break; - case PAGE_PROFILE: - $location = $lang['Viewing_profile']; - $location_url = "index.$phpEx"; - break; - case PAGE_VIEWONLINE: - $location = $lang['Viewing_online']; - $location_url = "viewonline.$phpEx"; - break; - case PAGE_VIEWMEMBERS: - $location = $lang['Viewing_member_list']; - $location_url = "memberlist.$phpEx"; - break; - case PAGE_PRIVMSGS: - $location = $lang['Viewing_priv_msgs']; - $location_url = "privmsg.$phpEx"; - break; - case PAGE_FAQ: - $location = $lang['Viewing_FAQ']; - $location_url = "faq.$phpEx"; - break; - default: - $location = $lang['Forum_index']; - $location_url = "index.$phpEx"; + switch($onlinerow_guest[$i]['session_page']) + { + case PAGE_INDEX: + $location = $lang['Forum_index']; + $location_url = "index.$phpEx"; + break; + case PAGE_POSTING: + $location = $lang['Posting_message']; + $location_url = "index.$phpEx"; + break; + case PAGE_LOGIN: + $location = $lang['Logging_on']; + $location_url = "index.$phpEx"; + break; + case PAGE_SEARCH: + $location = $lang['Searching_forums']; + $location_url = "search.$phpEx"; + break; + case PAGE_PROFILE: + $location = $lang['Viewing_profile']; + $location_url = "index.$phpEx"; + break; + case PAGE_VIEWONLINE: + $location = $lang['Viewing_online']; + $location_url = "viewonline.$phpEx"; + break; + case PAGE_VIEWMEMBERS: + $location = $lang['Viewing_member_list']; + $location_url = "memberlist.$phpEx"; + break; + case PAGE_PRIVMSGS: + $location = $lang['Viewing_priv_msgs']; + $location_url = "privmsg.$phpEx"; + break; + case PAGE_FAQ: + $location = $lang['Viewing_FAQ']; + $location_url = "faq.$phpEx"; + break; + default: + $location = $lang['Forum_index']; + $location_url = "index.$phpEx"; + } } + else + { + $location_url = append_sid("viewforum.$phpEx?" . POST_FORUM_URL . "=" . $onlinerow_guest[$i]['session_page']); + $location = $forum_data[$onlinerow_guest[$i]['session_page']]; + } + + $row_color = ( $guest_users % 2 ) ? $theme['td_color1'] : $theme['td_color2']; + $row_class = ( $guest_users % 2 ) ? $theme['td_class1'] : $theme['td_class2']; + + $template->assign_block_vars("guest_user_row", array( + "ROW_COLOR" => "#" . $row_color, + "ROW_CLASS" => $row_class, + "USERNAME" => $lang['Guest'], + "LASTUPDATE" => create_date($board_config['default_dateformat'], $onlinerow_guest[$i]['session_time'], $board_config['board_timezone']), + "LOCATION" => $location, + + "U_FORUM_LOCATION" => append_sid($location_url)) + ); } - else - { - $location_url = append_sid("viewforum.$phpEx?" . POST_FORUM_URL . "=" . $onlinerow_guest[$i]['session_page']); - $location = $forum_data[$onlinerow_guest[$i]['session_page']]; - } - - $row_color = ( $guest_users % 2 ) ? $theme['td_color1'] : $theme['td_color2']; - $row_class = ( $guest_users % 2 ) ? $theme['td_class1'] : $theme['td_class2']; - - $template->assign_block_vars("guest_user_row", array( - "ROW_COLOR" => "#" . $row_color, - "ROW_CLASS" => $row_class, - "USERNAME" => $lang['Guest'], - "LASTUPDATE" => create_date($board_config['default_dateformat'], $onlinerow_guest[$i]['session_time'], $board_config['board_timezone']), - "LOCATION" => $location, - - "U_FORUM_LOCATION" => append_sid($location_url)) - ); } - $l_g_user_s = ($guest_users == 1) ? $lang['User'] : $lang['Users']; - $l_is_are = ($guest_users == 1) ? $lang['is'] : $lang['are']; + $l_g_user_s = ( $guest_users == 1 ) ? $lang['Guest_user_online'] : $lang['Guest_users_online']; $template->assign_vars(array( - "TOTAL_GUEST_USERS_ONLINE" => $lang['There'] . " $l_is_are $guests_online " . $lang['Guest'] . " $l_g_user_s " . $lang['online']) + "TOTAL_GUEST_USERS_ONLINE" => sprintf($l_g_user_s, $guest_users)) ); } else { $template->assign_vars(array( - "TOTAL_GUEST_USERS_ONLINE" => $lang['There'] . " " . $lang['are'] . " 0 " . $lang['Guest'] . " " . $lang['Users'] . " " . $lang['online'], - "L_NO_GUESTS_BROWSING" => $lang['No_guests_browsing']) + "TOTAL_GUEST_USERS_ONLINE" => sprintf($lang['Guest_users_online'], 0, 0), + "L_NO_GUESTS_BROWSING" => $lang['No_users_browsing']) ); }