', $context['user']['name'], '', allowedTo('pm_read') ? ', ' . $txt[152] . ' ' . $context['user']['messages'] . ' ' . ($context['user']['messages'] == '1' ? $txt[471] : $txt[153]) . '' . $txt['newmessages4'] . ' ' . $context['user']['unread_messages'] . ' ' . ($context['user']['unread_messages'] == '1' ? $txt['newmessages0'] : $txt['newmessages1']) : '', '.'; } // Don't echo... then do what?! else return $context['user']; } // Display a menu bar, like is displayed at the top of the forum. function ssi_menubar($output_method = 'echo') { global $context; if ($output_method == 'echo') template_menu(); // What else could this do? else return $context; } // Show a logout link. function ssi_logout($redirect_to = '', $output_method = 'echo') { global $context, $txt, $scripturl, $sc; if ($redirect_to != '') $_SESSION['logout_url'] = $redirect_to; // Guests can't log out. if ($context['user']['is_guest']) return false; echo '', $txt[108], ''; } // Recent post list: [board] Subject by Poster Date function ssi_recentPosts($num_recent = 8, $exclude_boards = array(), $output_method = 'echo') { global $context, $settings, $scripturl, $txt, $db_prefix, $ID_MEMBER, $user_info, $modSettings; // Find all the posts. Newer ones will have higher IDs. $request = db_query(" SELECT m.posterTime, m.subject, m.ID_TOPIC, m.ID_MEMBER, m.ID_MSG, m.ID_BOARD, b.name AS bName, IFNULL(mem.realName, m.posterName) AS posterName, " . ($user_info['is_guest'] ? '1 AS isRead, 0 AS logTime' : ' IFNULL(lt.logTime, IFNULL(lmr.logTime, 0)) >= GREATEST(m.posterTime, m.modifiedTime) AS isRead, IFNULL(lt.logTime, IFNULL(lmr.logTime, 0)) AS logTime') . " FROM ({$db_prefix}messages AS m, {$db_prefix}boards AS b) LEFT JOIN {$db_prefix}members AS mem ON (mem.ID_MEMBER = m.ID_MEMBER)" . (!$user_info['is_guest'] ? " LEFT JOIN {$db_prefix}log_topics AS lt ON (lt.ID_TOPIC = m.ID_TOPIC AND lt.ID_MEMBER = $ID_MEMBER) LEFT JOIN {$db_prefix}log_mark_read AS lmr ON (lmr.ID_BOARD = m.ID_BOARD AND lmr.ID_MEMBER = $ID_MEMBER)" : '') . " WHERE m.ID_MSG >= " . ($modSettings['maxMsgID'] - 5 * $num_recent) . " AND b.ID_BOARD = m.ID_BOARD" . (empty($exclude_boards) ? '' : " AND b.ID_BOARD NOT IN (" . implode(', ', $exclude_boards) . ")") . " AND $user_info[query_see_board] ORDER BY m.ID_MSG DESC LIMIT $num_recent", __FILE__, __LINE__); $posts = array(); while ($row = mysql_fetch_assoc($request)) { // Censor the subject. censorText($row['subject']); // Build the array. $posts[] = array( 'board' => array( 'id' => $row['ID_BOARD'], 'name' => $row['bName'], 'href' => $scripturl . '?board=' . $row['ID_BOARD'] . '.0', 'link' => '' . $row['bName'] . '' ), 'topic' => $row['ID_TOPIC'], 'poster' => array( 'id' => $row['ID_MEMBER'], 'name' => $row['posterName'], 'href' => empty($row['ID_MEMBER']) ? '' : $scripturl . '?action=profile;u=' . $row['ID_MEMBER'], 'link' => empty($row['ID_MEMBER']) ? $row['posterName'] : '' . $row['posterName'] . '' ), 'subject' => $row['subject'], 'short_subject' => strlen(un_htmlspecialchars($row['subject'])) > 25 ? htmlspecialchars(substr(un_htmlspecialchars($row['subject']), 0, 22) . '...') : $row['subject'], 'time' => timeformat($row['posterTime']), 'timestamp' => $row['posterTime'], 'href' => $scripturl . '?topic=' . $row['ID_TOPIC'] . '.msg' . $row['ID_MSG'] . ';topicseen#msg' . $row['ID_MSG'], 'link' => '' . $row['subject'] . '', 'new' => !empty($row['isRead']), 'newtime' => $row['logTime'] ); } mysql_free_result($request); // Just return it. if ($output_method != 'echo' || empty($posts)) return $posts; echo ' '; foreach ($posts as $post) echo ' '; echo '
[', $post['board']['link'], '] ', $post['subject'], ' ', $txt[525], ' ', $post['poster']['link'], ' ', $post['new'] ? '' : '' . $txt[302] . '', ' ', $post['time'], '
'; } // Recent topic list: [board] Subject by Poster Date function ssi_recentTopics($num_recent = 8, $exclude_boards = array(), $output_method = 'echo') { global $context, $settings, $scripturl, $txt, $db_prefix, $ID_MEMBER, $user_info, $modSettings; // Find all the posts in distinct topics. Newer ones will have higher IDs. $request = db_query(" SELECT m.posterTime, ms.subject, m.ID_TOPIC, m.ID_MEMBER, m.ID_MSG, b.ID_BOARD, b.name AS bName, IFNULL(mem.realName, m.posterName) AS posterName, " . ($user_info['is_guest'] ? '1 AS isRead, 0 AS logTime' : ' IFNULL(lt.logTime, IFNULL(lmr.logTime, 0)) >= GREATEST(m.posterTime, m.modifiedTime) AS isRead, IFNULL(lt.logTime, IFNULL(lmr.logTime, 0)) AS logTime') . " FROM ({$db_prefix}messages AS m, {$db_prefix}topics AS t, {$db_prefix}boards AS b, {$db_prefix}messages AS ms) LEFT JOIN {$db_prefix}members AS mem ON (mem.ID_MEMBER = m.ID_MEMBER)" . (!$user_info['is_guest'] ? " LEFT JOIN {$db_prefix}log_topics AS lt ON (lt.ID_TOPIC = t.ID_TOPIC AND lt.ID_MEMBER = $ID_MEMBER) LEFT JOIN {$db_prefix}log_mark_read AS lmr ON (lmr.ID_BOARD = b.ID_BOARD AND lmr.ID_MEMBER = $ID_MEMBER)" : '') . " WHERE m.ID_MSG >= " . ($modSettings['maxMsgID'] - 8 * $num_recent) . " AND t.ID_LAST_MSG = m.ID_MSG AND b.ID_BOARD = t.ID_BOARD" . (empty($exclude_boards) ? '' : " AND b.ID_BOARD NOT IN (" . implode(', ', $exclude_boards) . ")") . " AND $user_info[query_see_board] AND ms.ID_MSG = t.ID_FIRST_MSG ORDER BY m.ID_MSG DESC LIMIT $num_recent", __FILE__, __LINE__); $posts = array(); while ($row = mysql_fetch_assoc($request)) { // Censor the subject. censorText($row['subject']); // Build the array. $posts[] = array( 'board' => array( 'id' => $row['ID_BOARD'], 'name' => $row['bName'], 'href' => $scripturl . '?board=' . $row['ID_BOARD'] . '.0', 'link' => '' . $row['bName'] . '' ), 'topic' => $row['ID_TOPIC'], 'poster' => array( 'id' => $row['ID_MEMBER'], 'name' => $row['posterName'], 'href' => empty($row['ID_MEMBER']) ? '' : $scripturl . '?action=profile;u=' . $row['ID_MEMBER'], 'link' => empty($row['ID_MEMBER']) ? $row['posterName'] : '' . $row['posterName'] . '' ), 'subject' => $row['subject'], 'short_subject' => strlen(un_htmlspecialchars($row['subject'])) > 25 ? htmlspecialchars(substr(un_htmlspecialchars($row['subject']), 0, 22) . '...') : $row['subject'], 'time' => timeformat($row['posterTime']), 'timestamp' => $row['posterTime'], 'href' => $scripturl . '?topic=' . $row['ID_TOPIC'] . '.msg' . $row['ID_MSG'] . ';topicseen#msg' . $row['ID_MSG'], 'link' => '' . $row['subject'] . '', 'new' => !empty($row['isRead']), 'newtime' => $row['logTime'] ); } mysql_free_result($request); // Just return it. if ($output_method != 'echo' || empty($posts)) return $posts; echo ' '; foreach ($posts as $post) echo ' '; echo '
[', $post['board']['link'], '] ', $post['subject'], ' ', $txt[525], ' ', $post['poster']['link'], ' ', $post['new'] ? '' : '' . $txt[302] . '', ' ', $post['time'], '
'; } // Show the top poster's name and profile link. function ssi_topPoster($topNumber = 1, $output_method = 'echo') { global $db_prefix, $scripturl; // Find the latest poster. $request = db_query(" SELECT ID_MEMBER, realName FROM {$db_prefix}members ORDER BY posts DESC LIMIT $topNumber", __FILE__, __LINE__); $return = array(); while ($row = mysql_fetch_assoc($request)) $return[] = array( 'id' => $row['ID_MEMBER'], 'name' => $row['realName'], 'href' => $scripturl . '?action=profile;u=' . $row['ID_MEMBER'], 'link' => '' . $row['realName'] . '' ); mysql_free_result($request); // Just return all the top posters. if ($output_method != 'echo') return $return; // Make a quick array to list the links in. $temp_array = array(); foreach ($return as $member) $temp_array[] = $member['link']; echo implode(', ', $temp_array); } // Show boards by activity. function ssi_topBoards($num_top = 10, $output_method = 'echo') { global $context, $settings, $db_prefix, $txt, $scripturl, $ID_MEMBER, $user_info; // Find boards with lots of posts. $request = db_query(" SELECT b.name, b.numTopics, b.numPosts, b.ID_BOARD," . (!$user_info['is_guest'] ? ' 1 AS isRead' : ' (IFNULL(lb.logTime, 0) >= b.lastUpdated) AS isRead') . " FROM {$db_prefix}boards AS b LEFT JOIN {$db_prefix}log_boards AS lb ON (lb.ID_BOARD = b.ID_BOARD AND lb.ID_MEMBER = $ID_MEMBER) WHERE $user_info[query_see_board] ORDER BY b.numPosts DESC LIMIT $num_top", __FILE__, __LINE__); $boards = array(); while ($row = mysql_fetch_assoc($request)) $boards[] = array( 'id' => $row['ID_BOARD'], 'num_posts' => $row['numPosts'], 'num_topics' => $row['numTopics'], 'name' => $row['name'], 'new' => empty($row['isRead']), 'href' => $scripturl . '?board=' . $row['ID_BOARD'] . '.0', 'link' => '' . $row['name'] . '' ); mysql_free_result($request); // If we shouldn't output or have nothing to output, just jump out. if ($output_method != 'echo' || empty($boards)) return $boards; echo ' '; foreach ($boards as $board) echo ' '; echo '
', $txt['smf82'], ' ', $txt[330], ' ', $txt[21], '
', $board['link'], $board['new'] ? ' ' . $txt[302] . '' : '', ' ', $board['num_topics'], ' ', $board['num_posts'], '
'; } // Shows the top topics. function ssi_topTopics($type = 'replies', $num_topics = 10, $output_method = 'echo') { global $db_prefix, $txt, $scripturl, $ID_MEMBER, $user_info; $request = db_query(" SELECT m.subject, m.ID_TOPIC, t.numViews, t.numReplies FROM {$db_prefix}topics AS t, {$db_prefix}messages AS m, {$db_prefix}boards AS b WHERE m.ID_MSG = t.ID_FIRST_MSG AND t.ID_BOARD = b.ID_BOARD AND $user_info[query_see_board] ORDER BY t.num" . ($type != 'replies' ? 'Views' : 'Replies') . " DESC LIMIT $num_topics", __FILE__, __LINE__); $topics = array(); while ($row = mysql_fetch_assoc($request)) { censorText($row['subject']); $topics[] = array( 'id' => $row['ID_TOPIC'], 'subject' => $row['subject'], 'num_replies' => $row['numReplies'], 'num_views' => $row['numViews'], 'href' => $scripturl . '?topic=' . $row['ID_TOPIC'] . '.0', 'link' => '' . $row['subject'] . '', ); } mysql_free_result($request); if ($output_method != 'echo' || empty($topics)) return $topics; echo ' '; foreach ($topics as $topic) echo ' '; echo '
', $txt[301], ' ', $txt[110], '
', $topic['link'], ' ', $topic['num_views'], ' ', $topic['num_replies'], '
'; } // Shows the top topics, by replies. function ssi_topTopicsReplies($num_topics = 10, $output_method = 'echo') { return ssi_topTopics('replies', $num_topics, $output_method); } // Shows the top topics, by views. function ssi_topTopicsViews($num_topics = 10, $output_method = 'echo') { return ssi_topTopics('views', $num_topics, $output_method); } // Show a link to the latest member: Please welcome, Someone, out latest member. function ssi_latestMember($output_method = 'echo') { global $db_prefix, $txt, $scripturl, $modSettings; if ($output_method == 'echo') echo ' ', $txt[201], ' ', $modSettings['latestRealName'], '', $txt[581], '
'; else return array( 'id' => $modSettings['latestMember'], 'name' => $modSettings['latestRealName'], 'href' => $scripturl . '?action=profile;u=' . $modSettings['latestMember'], 'link' => '' . $modSettings['latestRealName'] . '' ); } // Show some basic stats: Total This: XXXX, etc. function ssi_boardStats($output_method = 'echo') { global $db_prefix, $txt, $scripturl, $modSettings; $totals = array( 'members' => $modSettings['memberCount'], 'posts' => $modSettings['totalMessages'], 'topics' => $modSettings['totalTopics'] ); $result = db_query(" SELECT COUNT(ID_BOARD) FROM {$db_prefix}boards", __FILE__, __LINE__); list ($totals['boards']) = mysql_fetch_row($result); mysql_free_result($result); $result = db_query(" SELECT COUNT(ID_CAT) FROM {$db_prefix}categories", __FILE__, __LINE__); list ($totals['categories']) = mysql_fetch_row($result); mysql_free_result($result); if ($output_method != 'echo') return $totals; echo ' ', $txt[488], ': ', $totals['members'], '
', $txt[489], ': ', $totals['posts'], '
', $txt[490], ': ', $totals['topics'], '
', $txt[658], ': ', $totals['categories'], '
', $txt[665], ': ', $totals['boards']; } // Shows a list of online users: YY Guests, ZZ Users and then a list... function ssi_whosOnline($output_method = 'echo') { global $scripturl, $db_prefix, $txt; global $modSettings; // Load the users online right now. $result = db_query(" SELECT lo.ID_MEMBER, lo.logTime, lo.url, mem.realName, mem.memberName, mem.showOnline, mg.onlineColor, mg.ID_GROUP FROM {$db_prefix}log_online AS lo LEFT JOIN {$db_prefix}members AS mem ON (mem.ID_MEMBER = lo.ID_MEMBER) LEFT JOIN {$db_prefix}membergroups AS mg ON (mg.ID_GROUP = IF(mem.ID_GROUP = 0, mem.ID_POST_GROUP, mem.ID_GROUP))", __FILE__, __LINE__); $return['users'] = array(); $return['guests'] = 0; $return['hidden'] = 0; $return['spiders'] = array(); $return['num_spiders'] = 0; while ($row = mysql_fetch_assoc($result)) { if (!isset($row['realName'])) { // Get the request parameters.. $actions = @unserialize($row['url']); // Is a spider? $is_spider = ob_googlebot_getAgent($actions['USER_AGENT'], $spider_name, $agent, $row['ID_MEMBER'] == 0); if (!$is_spider) $return['guests']++; else { $return['num_spiders']++; if ($modSettings['ob_googlebot_display_agent']) $spider_name = $agent; if ($modSettings['ob_googlebot_count_all_instances'] && $modSettings['ob_googlebot_display_all_instances']) $return['spiders'][] = $spider_name; else $return['spiders'][$agent] = $spider_name; } } elseif (!empty($row['showOnline']) || allowedTo('moderate_forum')) { // Some basic color coding... if (!empty($row['onlineColor'])) $link = '' . $row['realName'] . ''; else $link = '' . $row['realName'] . ''; $return['users'][$row['logTime'] . $row['memberName']] = array( 'id' => $row['ID_MEMBER'], 'username' => $row['memberName'], 'name' => $row['realName'], 'group' => $row['ID_GROUP'], 'href' => $scripturl . '?action=profile;u=' . $row['ID_MEMBER'], 'link' => $link, 'hidden' => empty($row['showOnline']), 'is_last' => false, ); } else $return['hidden']++; } mysql_free_result($result); if (!empty($return['users'])) { krsort($return['users']); $userlist = array_keys($return['users']); $return['users'][$userlist[count($userlist) - 1]]['is_last'] = true; } $return['num_users'] = count($return['users']) + $return['hidden']; $return['total_users'] = $return['num_users'] + $return['guests'] + ($modSettings['ob_googlebot_count_most_online'] ? $return['num_spiders'] : 0); ksort($return['spiders']); // Allowed user to see spiders online? if (!allowedTo('googlebot_view')) { $return['spiders'] = array(); $return['guests'] += $return['num_spiders']; } // Don't count all instances of a spider, only 1 for each different spider if (!empty($return['spiders']) && !$modSettings['ob_googlebot_count_all_instances']) $return['num_spiders'] = count($return['spiders']); // Diplay how many instances of each spider if (!empty($return['spiders']) && $modSettings['ob_googlebot_count_all_instances'] && $modSettings['ob_googlebot_display_all_instances']) { $spider_grouped = array_count_values($return['spiders']); $return['spiders'] = array(); foreach ($spider_grouped as $k => $v) $return['spiders'][$k] = $k . ($v == 1 ? '' : ' (' . $v . ')'); } if ($output_method != 'echo') return $return; echo ' ', (empty($return['spiders']) ? '' : $return['num_spiders'] . ' ' . ($return['num_spiders'] == 1 ? $txt['ob_googlebot_spider'] : $txt['ob_googlebot_spiders']) . ', '), $return['guests'], ' ', $return['guests'] == 1 ? $txt['guest'] : $txt['guests'], ', ', $return['num_users'], ' ', $return['num_users'] == 1 ? $txt['user'] : $txt['users'], $return['hidden'] > 0 ? ' (' . $return['hidden'] . ' ' . $txt['hidden'] . ')' : '', '
'; foreach ($return['users'] as $user) echo $user['hidden'] ? '' . $user['link'] . '' : $user['link'], $user['is_last'] ? '' : ', '; if (!empty($return['spiders'])) { if ($modSettings['ob_googlebot_display_own_list']) echo '
'; else { if (!empty($return['users'])) echo ', '; } echo implode(', ', $return['spiders']); } } // Just like whosOnline except it also logs the online presence. function ssi_logOnline($output_method = 'echo') { writeLog(); if ($output_method != 'echo') return ssi_whosOnline($output_method); else ssi_whosOnline($output_method); } // Shows a login box. function ssi_login($redirect_to = '', $output_method = 'echo') { global $scripturl, $txt, $user_info; if ($redirect_to != '') $_SESSION['login_url'] = $redirect_to; if ($output_method != 'echo' || !$user_info['is_guest']) return $user_info['is_guest']; echo '
 
 
'; } // Show the most-voted-in poll. function ssi_topPoll($output_method = 'echo') { // Just use recentPoll, no need to duplicate code... return ssi_recentPoll($output_method, true); } // Show the most recently posted poll. function ssi_recentPoll($output_method = 'echo', $topPollInstead = false) { global $db_prefix, $txt, $ID_MEMBER, $settings, $boardurl, $sc, $user_info; $boardsAllowed = array_intersect(boardsAllowedTo('poll_view'), boardsAllowedTo('poll_vote')); if (empty($boardsAllowed)) return array(); $request = db_query(" SELECT p.ID_POLL, p.question, t.ID_TOPIC, p.maxVotes FROM ({$db_prefix}polls AS p, {$db_prefix}boards AS b, {$db_prefix}topics AS t" . ($topPollInstead ? ", {$db_prefix}poll_choices AS pc" : '') . ") LEFT JOIN {$db_prefix}log_polls AS lp ON (lp.ID_POLL = p.ID_POLL AND lp.ID_MEMBER = $ID_MEMBER) WHERE p.votingLocked = 0" . ($topPollInstead ? " AND pc.ID_POLL = p.ID_POLL" : '') . " AND lp.ID_CHOICE IS NULL AND t.ID_POLL = p.ID_POLL AND b.ID_BOARD = t.ID_BOARD AND $user_info[query_see_board]" . (!in_array(0, $boardsAllowed) ? " AND b.ID_BOARD IN (" . implode(', ', $boardsAllowed) . ")" : '') . " ORDER BY " . ($topPollInstead ? 'pc.votes' : 'p.ID_POLL') . " DESC LIMIT 1", __FILE__, __LINE__); $row = mysql_fetch_assoc($request); mysql_free_result($request); // This user has voted on all the polls. if ($row === false) return array(); $request = db_query(" SELECT COUNT(DISTINCT ID_MEMBER) FROM {$db_prefix}log_polls WHERE ID_POLL = $row[ID_POLL]", __FILE__, __LINE__); list ($total) = mysql_fetch_row($request); mysql_free_result($request); $request = db_query(" SELECT ID_CHOICE, label, votes FROM {$db_prefix}poll_choices WHERE ID_POLL = $row[ID_POLL]", __FILE__, __LINE__); $options = array(); while ($rowChoice = mysql_fetch_assoc($request)) $options[$rowChoice['ID_CHOICE']] = array($rowChoice['label'], $rowChoice['votes']); mysql_free_result($request); $return = array( 'id' => $row['ID_POLL'], 'image' => 'poll', 'question' => $row['question'], 'total_votes' => $total, 'is_locked' => false, 'topic' => $row['ID_TOPIC'], 'options' => array() ); // Calculate the percentages and bar lengths... $divisor = $return['total_votes'] == 0 ? 1 : $return['total_votes']; foreach ($options as $i => $option) { $bar = floor(($option[1] * 100) / $divisor); $barWide = $bar == 0 ? 1 : floor(($bar * 5) / 3); $return['options'][$i] = array( 'percent' => $bar, 'votes' => $option[1], 'bar' => '-', 'option' => doUBBC($option[0]), 'vote_button' => '' ); } $return['allowed_warning'] = $row['maxVotes'] > 1 ? sprintf($txt['poll_options6'], $row['maxVotes']) : ''; if ($output_method != 'echo') return $return; echo '
'; foreach ($return['options'] as $option) echo ' '; echo '
', $return['question'], '
', $return['allowed_warning'], '
'; } function ssi_showPoll($topic = null, $output_method = 'echo') { global $db_prefix, $txt, $ID_MEMBER, $settings, $boardurl, $sc, $user_info; $boardsAllowed = boardsAllowedTo('poll_view'); if (empty($boardsAllowed)) return array(); if ($topic === null && isset($_REQUEST['ssi_topic'])) $topic = (int) $_REQUEST['ssi_topic']; else $topic = (int) $topic; $request = db_query(" SELECT p.ID_POLL, p.question, p.votingLocked, p.hideResults, p.expireTime, p.maxVotes FROM {$db_prefix}topics AS t, {$db_prefix}polls AS p, {$db_prefix}boards AS b WHERE p.ID_POLL = t.ID_POLL AND t.ID_TOPIC = $topic AND b.ID_BOARD = t.ID_BOARD AND $user_info[query_see_board]" . (!in_array(0, $boardsAllowed) ? " AND b.ID_BOARD IN (" . implode(', ', $boardsAllowed) . ")" : '') . " LIMIT 1", __FILE__, __LINE__); // Either this topic has no poll, or the user cannot view it. if (mysql_num_rows($request) == 0) return array(); $row = mysql_fetch_assoc($request); mysql_free_result($request); // Check if they can vote. if (!empty($row['expireTime']) && $row['expireTime'] < time()) $allow_vote = false; elseif ($user_info['is_guest'] || !empty($row['votingLocked']) || !allowedTo('poll_vote')) $allow_vote = false; else { $request = db_query(" SELECT ID_MEMBER FROM {$db_prefix}log_polls WHERE ID_POLL = $row[ID_POLL] AND ID_MEMBER = $ID_MEMBER LIMIT 1", __FILE__, __LINE__); $allow_vote = mysql_num_rows($request) == 0; mysql_free_result($request); } $request = db_query(" SELECT COUNT(DISTINCT ID_MEMBER) FROM {$db_prefix}log_polls WHERE ID_POLL = $row[ID_POLL]", __FILE__, __LINE__); list ($total) = mysql_fetch_row($request); mysql_free_result($request); $request = db_query(" SELECT ID_CHOICE, label, votes FROM {$db_prefix}poll_choices WHERE ID_POLL = $row[ID_POLL]", __FILE__, __LINE__); $options = array(); $total_votes = 0; while ($rowChoice = mysql_fetch_assoc($request)) { $options[$rowChoice['ID_CHOICE']] = array($rowChoice['label'], $rowChoice['votes']); $total_votes += $rowChoice['votes']; } mysql_free_result($request); $return = array( 'id' => $row['ID_POLL'], 'image' => empty($pollinfo['votingLocked']) ? 'poll' : 'locked_poll', 'question' => $row['question'], 'total_votes' => $total, 'is_locked' => !empty($pollinfo['votingLocked']), 'allow_vote' => $allow_vote, 'topic' => $topic ); // Calculate the percentages and bar lengths... $divisor = $total_votes == 0 ? 1 : $total_votes; foreach ($options as $i => $option) { $bar = floor(($option[1] * 100) / $divisor); $barWide = $bar == 0 ? 1 : floor(($bar * 5) / 3); $return['options'][$i] = array( 'percent' => $bar, 'votes' => $option[1], 'bar' => '-', 'option' => doUBBC($option[0]), 'vote_button' => '' ); } $return['allowed_warning'] = $row['maxVotes'] > 1 ? sprintf($txt['poll_options6'], $row['maxVotes']) : ''; if ($output_method != 'echo') return $return; if ($return['allow_vote']) { echo '
'; foreach ($return['options'] as $option) echo ' '; echo '
', $return['question'], '
', $return['allowed_warning'], '
'; } else { echo ' '; foreach ($return['options'] as $option) echo ' '; echo '
', $return['question'], '
', $option['option'], ' ', $option['bar'], ' ', $option['votes'], ' (', $option['percent'], '%)
', $txt['smf24'], ': ', $return['total_votes'], '
'; } } // Takes care of voting - don't worry, this is done automatically. function ssi_pollVote() { global $db_prefix, $ID_MEMBER, $user_info, $sc; echo '   '; if (!isset($_POST['sc']) || $_POST['sc'] != $sc) return; // This can cause weird errors! (ie. copyright missing.) checkSession(); if (empty($_POST['options']) || !isset($_POST['poll'])) return; $_POST['poll'] = (int) $_POST['poll']; // Check if they have already voted, or voting is locked. $request = db_query(" SELECT IFNULL(lp.ID_CHOICE, -1) AS selected, p.votingLocked, p.expireTime, p.maxVotes FROM ({$db_prefix}polls AS p, {$db_prefix}topics AS t, {$db_prefix}boards AS b) LEFT JOIN {$db_prefix}log_polls AS lp ON (lp.ID_POLL = p.ID_POLL AND lp.ID_MEMBER = $ID_MEMBER) WHERE p.ID_POLL = $_POST[poll] AND t.ID_POLL = $_POST[poll] AND b.ID_BOARD = t.ID_BOARD AND $user_info[query_see_board] LIMIT 1", __FILE__, __LINE__); if (mysql_num_rows($request) == 0) return; $row = mysql_fetch_assoc($request); mysql_free_result($request); if (!empty($row['votingLocked']) || $row['selected'] != -1 || (!empty($row['expireTime']) && time() > $row['expireTime'])) return; // Too many options checked? if (count($_REQUEST['options']) > $row['maxVotes']) return; $options = array(); $setString = ''; foreach ($_REQUEST['options'] as $id) { $id = (int) $id; $options[] = $id; $setString .= " ($_POST[poll], $ID_MEMBER, $id),"; } $setString = substr($setString, 0, -1); // Add their vote in to the tally. db_query(" INSERT INTO {$db_prefix}log_polls (ID_POLL, ID_MEMBER, ID_CHOICE) VALUES $setString", __FILE__, __LINE__); db_query(" UPDATE {$db_prefix}poll_choices SET votes = votes + 1 WHERE ID_POLL = $_POST[poll] AND ID_CHOICE IN (" . implode(', ', $options) . ") LIMIT " . count($options), __FILE__, __LINE__); } // Show a search box. function ssi_quickSearch($output_method = 'echo') { global $scripturl, $txt; if ($output_method != 'echo') return $scripturl . '?action=search'; echo '
'; } // Show what would be the forum news. function ssi_news($output_method = 'echo') { global $context; if ($output_method != 'echo') return $context['random_news_line']; echo $context['random_news_line']; } // Show today's birthdays. function ssi_todaysBirthdays($output_method = 'echo') { global $context, $scripturl; if (!smf_loadCalendarInfo() || empty($context['calendar_birthdays'])) return array(); if ($output_method != 'echo') return $context['calendar_birthdays']; foreach ($context['calendar_birthdays'] as $member) echo ' ' . $member['name'] . (isset($member['age']) ? ' (' . $member['age'] . ')' : '') . '' . (!$member['is_last'] ? ', ' : ''); } // Show today's holidays. function ssi_todaysHolidays($output_method = 'echo') { global $context; if (!smf_loadCalendarInfo() || empty($context['calendar_holidays'])) return array(); if ($output_method != 'echo') return $context['calendar_holidays']; echo ' ', implode(', ', $context['calendar_holidays']); } // Show today's events. function ssi_todaysEvents($output_method = 'echo') { global $context; if (!smf_loadCalendarInfo() || empty($context['calendar_events'])) return array(); if ($output_method != 'echo') return $context['calendar_events']; foreach ($context['calendar_events'] as $event) { if ($event['can_edit']) echo ' * '; echo ' ' . $event['title'] . '' . (!$event['is_last'] ? ', ' : ''); } } // Show all calendar entires for today. (birthdays, holodays, and events.) function ssi_todaysCalendar($output_method = 'echo') { global $context, $modSettings, $txt, $scripturl; if (!smf_loadCalendarInfo()) return array(); if ($output_method != 'echo') return array( 'birthdays' => $context['calendar_birthdays'], 'holidays' => $context['calendar_holidays'], 'events' => $context['calendar_events'] ); if (!empty($context['calendar_holidays'])) echo ' ' . $txt['calendar5'] . ' ' . implode(', ', $context['calendar_holidays']) . '
'; if (!empty($context['calendar_birthdays'])) { echo ' ' . $txt['calendar3b'] . ' '; foreach ($context['calendar_birthdays'] as $member) echo ' ', $member['name'], isset($member['age']) ? ' (' . $member['age'] . ')' : '', '', !$member['is_last'] ? ', ' : ''; echo '
'; } if (!empty($context['calendar_events'])) { echo ' ' . $txt['calendar4b'] . ' '; foreach ($context['calendar_events'] as $event) { if ($event['can_edit']) echo ' * '; echo ' ' . $event['title'] . '' . (!$event['is_last'] ? ', ' : ''); } } } // Show the latest news, with a template... by board. function ssi_boardNews($board = null, $limit = null, $start = null, $length = null, $output_method = 'echo') { global $scripturl, $db_prefix, $txt; global $settings, $modSettings, $context; loadLanguage('Stats'); // Must be integers.... if ($limit === null) $limit = isset($_GET['limit']) ? (int) $_GET['limit'] : 5; else $limit = (int) $limit; if ($start === null) $start = isset($_GET['start']) ? (int) $_GET['start'] : 0; else $start = (int) $start; if ($board !== null) $board = (int) $board; elseif (isset($_GET['board'])) $board = (int) $_GET['board']; if ($length === null) $length = isset($_GET['length']) ? (int) $_GET['length'] : 0; else $length = (int) $length; // Make sure guests can see this board. $request = db_query(" SELECT ID_BOARD FROM {$db_prefix}boards WHERE " . ($board === null ? '' : "ID_BOARD = $board AND ") . "FIND_IN_SET(-1, memberGroups) LIMIT 1", __FILE__, __LINE__); if (mysql_num_rows($request) == 0) { if ($output_method == 'echo') die($txt['smf_news_error2']); else return array(); } list ($board) = mysql_fetch_row($request); mysql_free_result($request); // Find the posts. $request = db_query(" SELECT m.icon, m.subject, m.body, IFNULL(mem.realName, m.posterName) AS posterName, m.posterTime, t.numReplies, t.ID_TOPIC, m.ID_MEMBER, m.smileysEnabled FROM ({$db_prefix}topics AS t, {$db_prefix}messages AS m) LEFT JOIN {$db_prefix}members AS mem ON (mem.ID_MEMBER = m.ID_MEMBER) WHERE t.ID_BOARD = $board AND m.ID_MSG = t.ID_FIRST_MSG ORDER BY m.ID_MSG DESC LIMIT $start, $limit", __FILE__, __LINE__); $return = array(); while ($row = mysql_fetch_assoc($request)) { // If we want to limit the length of the post. if (!empty($length) && strlen($row['body']) > $length) { $row['body'] = substr($row['body'], 0, $length); // The first space or line break. (
, etc.) $cutoff = max(strrpos($row['body'], ' '), strrpos($row['body'], '<')); if ($cutoff !== false) $row['body'] = substr($row['body'], 0, $cutoff); $row['body'] .= '...'; } $row['body'] = doUBBC($row['body'], $row['smileysEnabled']); censorText($row['subject']); censorText($row['body']); $return[] = array( 'id' => $row['ID_TOPIC'], 'icon' => '' . $row['icon'] . '', 'subject' => $row['subject'], 'time' => timeformat($row['posterTime']), 'timestamp' => $row['posterTime'], 'body' => $row['body'], 'href' => $scripturl . '?topic=' . $row['ID_TOPIC'] . '.0', 'link' => '' . $row['numReplies'] . ' ' . ($row['numReplies'] == 1 ? $txt['smf_news_1'] : $txt['smf_news_2']) . '', 'replies' => $row['numReplies'], 'new_comment' => '' . $txt['smf_news_3'] . '', 'poster' => array( 'id' => $row['ID_MEMBER'], 'name' => $row['posterName'], 'href' => !empty($row['ID_MEMBER']) ? $scripturl . '?action=profile;u=' . $row['ID_MEMBER'] : '', 'link' => !empty($row['ID_MEMBER']) ? '' . $row['posterName'] . '' : $row['posterName'] ), 'is_last' => false ); } mysql_free_result($request); if (empty($return)) return $return; $return[count($return) - 1]['is_last'] = true; if ($output_method != 'echo') return $return; foreach ($return as $news) { echo '
', $news['icon'], ' ', $news['subject'], '
', $news['time'], ' ', $txt[525], ' ', $news['poster']['link'], '

', $news['body'], '

', $news['link'], ' | ', $news['new_comment'], '

'; if (!$news['is_last']) echo '

'; } } // Show the most recent events. function ssi_recentEvents($max_events = 7, $output_method = 'echo') { global $db_prefix, $user_info, $scripturl, $modSettings, $txt, $sc; // Find all events which are happening in the near future that the member can see. $request = db_query(" SELECT cal.ID_EVENT, DAYOFMONTH(cal.eventDate) AS day, cal.title, cal.ID_MEMBER, cal.ID_TOPIC, cal.ID_BOARD, t.ID_FIRST_MSG FROM {$db_prefix}calendar AS cal, {$db_prefix}boards AS b, {$db_prefix}topics AS t WHERE cal.eventDate >= '" . strftime('%Y-%m-%d', forum_time(false)) . "' AND cal.ID_TOPIC = t.ID_TOPIC AND cal.ID_BOARD = b.ID_BOARD AND $user_info[query_see_board] ORDER BY cal.eventDate DESC LIMIT $max_events", __FILE__, __LINE__); $return = array(); $duplicates = array(); while ($row = mysql_fetch_assoc($request)) { // Check if we've already come by an event linked to this same topic with the same title... and don't display it if we have. if (!empty($duplicates[$row['title'] . $row['ID_TOPIC']])) continue; // Censor the title. censorText($row['title']); $return[$row['day']][] = array( 'id' => $row['ID_EVENT'], 'title' => $row['title'], 'can_edit' => allowedTo('calendar_edit_any') || ($row['ID_MEMBER'] == $ID_MEMBER && allowedTo('calendar_edit_own')), 'modify_href' => $scripturl . '?action=post;msg=' . $row['ID_FIRST_MSG'] . ';topic=' . $row['ID_TOPIC'] . '.0;calendar;eventid=' . $row['ID_EVENT'] . ';sesc=' . $sc, 'href' => $scripturl . '?topic=' . $row['ID_TOPIC'] . '.0', 'link' => '' . $row['title'] . '', 'is_last' => false ); // Let's not show this one again, huh? $duplicates[$row['title'] . $row['ID_TOPIC']] = true; } mysql_free_result($request); foreach ($return as $mday => $array) $return[$mday][count($array) - 1]['is_last'] = true; if ($output_method != 'echo' || empty($return)) return $return; // Well the output method is echo. echo ' ' . $txt['calendar4'] . ' '; foreach ($return as $mday => $array) foreach ($array as $event) { if ($event['can_edit']) echo ' * '; echo ' ' . $event['title'] . '' . (!$event['is_last'] ? ', ' : ''); } } // Load the calendar information. (internal...) function smf_loadCalendarInfo() { global $modSettings, $context, $user_info, $scripturl, $sc, $ID_MEMBER; // Get the current forum time and check whether the statistics are up to date. if (!isset($modSettings['cal_today_updated']) || $modSettings['cal_today_updated'] != strftime('%Y%m%d', forum_time(false))) updateStats('calendar'); // Get the current member time/date. $day = (int) strftime('%d', forum_time()); // Load the holidays for today... if (isset($modSettings['cal_today_holiday'])) $holidays = unserialize($modSettings['cal_today_holiday']); // ... the birthdays for today... if (isset($modSettings['cal_today_birthday'])) $bday = unserialize($modSettings['cal_today_birthday']); // ... and the events for today. if (isset($modSettings['cal_today_event'])) $events = unserialize($modSettings['cal_today_event']); // No events, birthdays, or holidays... don't show anything. if (empty($holidays) && empty($bday) && empty($events)) return false; // This shouldn't be less than one! if (empty($modSettings['cal_days_for_index']) || $modSettings['cal_days_for_index'] < 1) $modSettings['cal_days_for_index'] = 1; $context['calendar_only_today'] = $modSettings['cal_days_for_index'] == 1; // Get the last day of the month. $nLastDay = (int) strftime('%d', mktime(0, 0, 0, strftime('%m') == 12 ? 1 : strftime('%m') + 1, 0, strftime('%m') == 12 ? strftime('%Y') + 1 : strftime('%Y'))); // This is used to show the "how-do-I-edit" help. $context['calendar_can_edit'] = allowedTo('calendar_edit_any'); // Holidays between now and now + days. $context['calendar_holidays'] = array(); for ($i = $day; $i < $day + $modSettings['cal_days_for_index']; $i++) { if (isset($holidays[$i % $nLastDay == 0 ? $i : $i % $nLastDay])) $context['calendar_holidays'] = array_merge($context['calendar_holidays'], $holidays[$i % $nLastDay == 0 ? $i : $i % $nLastDay]); } // Happy Birthday, guys and gals! $context['calendar_birthdays'] = array(); for ($i = $day; $i < $day + $modSettings['cal_days_for_index']; $i++) { if (isset($bday[$i % $nLastDay == 0 ? $i : $i % $nLastDay])) { foreach ($bday[$i % $nLastDay == 0 ? $i : $i % $nLastDay] as $index => $dummy) $bday[$i % $nLastDay == 0 ? $i : $i % $nLastDay][$index]['is_today'] = ($i % $nLastDay == 0 ? $i : $i % $nLastDay) == $day; $context['calendar_birthdays'] = array_merge($context['calendar_birthdays'], $bday[$i % $nLastDay == 0 ? $i : $i % $nLastDay]); } } $context['calendar_events'] = array(); $duplicates = array(); for ($i = $day; $i < $day + $modSettings['cal_days_for_index']; $i++) { if (isset($events[$i % $nLastDay == 0 ? $i : $i % $nLastDay])) foreach ($events[$i % $nLastDay == 0 ? $i : $i % $nLastDay] as $ev => $event) { if ((count(array_intersect($user_info['groups'], $event['allowed_groups'])) != 0 || allowedTo('admin_forum'))) { if (isset($duplicates[$events[$i % $nLastDay == 0 ? $i : $i % $nLastDay][$ev]['topic'] . $events[$i % $nLastDay == 0 ? $i : $i % $nLastDay][$ev]['title']])) { unset($events[$i % $nLastDay == 0 ? $i : $i % $nLastDay][$ev]); continue; } $this_event = &$events[$i % $nLastDay == 0 ? $i : $i % $nLastDay][$ev]; $this_event['href'] = $scripturl . '?topic=' . $this_event['topic'] . '.0'; $this_event['modify_href'] = $scripturl . '?action=post;msg=' . $this_event['msg'] . ';topic=' . $this_event['topic'] . '.0;calendar;eventid=' . $this_event['id'] . ';sesc=' . $sc; $this_event['can_edit'] = allowedTo('calendar_edit_any') || ($this_event['poster'] == $ID_MEMBER && allowedTo('calendar_edit_own')); $this_event['is_today'] = ($i % $nLastDay == 0 ? $i : $i % $nLastDay) == $day; $duplicates[$this_event['topic'] . $this_event['title']] = true; } else unset($events[$i % $nLastDay == 0 ? $i : $i % $nLastDay][$ev]); } if (isset($events[$i % $nLastDay == 0 ? $i : $i % $nLastDay])) $context['calendar_events'] = array_merge($context['calendar_events'], $events[$i % $nLastDay == 0 ? $i : $i % $nLastDay]); } for ($i = 0, $n = count($context['calendar_birthdays']); $i < $n; $i++) $context['calendar_birthdays'][$i]['is_last'] = !isset($context['calendar_birthdays'][$i + 1]); for ($i = 0, $n = count($context['calendar_events']); $i < $n; $i++) $context['calendar_events'][$i]['is_last'] = !isset($context['calendar_events'][$i + 1]); return !empty($context['calendar_holidays']) || !empty($context['calendar_birthdays']) || !empty($context['calendar_events']); } // Check the passed ID_MEMBER/password. If $is_username is true, treats $id as a username. function ssi_checkPassword($id = null, $password = null, $is_username = false) { global $db_prefix; // If $id is null, this was most likely called from a query string and should do nothing. if ($id === null) return; $request = db_query(" SELECT passwd, memberName, is_activated FROM {$db_prefix}members WHERE " . ($is_username ? 'memberName' : 'ID_MEMBER') . " = '$id' LIMIT 1", __FILE__, __LINE__); list ($pass, $user, $active) = mysql_fetch_row($request); mysql_free_result($request); return md5_hmac($password, strtolower($user)) == $pass && !empty($active); } ?>