PageRenderTime 41ms CodeModel.GetById 15ms RepoModel.GetById 1ms app.codeStats 0ms

/index.php

http://seo-phpbb.googlecode.com/
PHP | 143 lines | 100 code | 21 blank | 22 comment | 22 complexity | 27f0af189a15c11982835f7b919afd83 MD5 | raw file
Possible License(s): AGPL-1.0
  1. <?php
  2. /**
  3. *
  4. * @package phpBB3
  5. * @version $Id: index.php 8638 2008-06-09 17:11:26Z acydburn $
  6. * @copyright (c) 2005 phpBB Group
  7. * @license http://opensource.org/licenses/gpl-license.php GNU Public License
  8. *
  9. */
  10. /**
  11. */
  12. /**
  13. * @ignore
  14. */
  15. define('IN_PHPBB', true);
  16. $phpbb_root_path = (defined('PHPBB_ROOT_PATH')) ? PHPBB_ROOT_PATH : './';
  17. $phpEx = substr(strrchr(__FILE__, '.'), 1);
  18. include($phpbb_root_path . 'common.' . $phpEx);
  19. include($phpbb_root_path . 'includes/functions_display.' . $phpEx);
  20. // Start session management
  21. $user->session_begin();
  22. $auth->acl($user->data);
  23. $user->setup('viewforum');
  24. display_forums('', $config['load_moderators']);
  25. // Set some stats, get posts count from forums data if we... hum... retrieve all forums data
  26. $total_posts = $config['num_posts'];
  27. $total_topics = $config['num_topics'];
  28. $total_users = $config['num_users'];
  29. $l_total_user_s = ($total_users == 0) ? 'TOTAL_USERS_ZERO' : 'TOTAL_USERS_OTHER';
  30. $l_total_post_s = ($total_posts == 0) ? 'TOTAL_POSTS_ZERO' : 'TOTAL_POSTS_OTHER';
  31. $l_total_topic_s = ($total_topics == 0) ? 'TOTAL_TOPICS_ZERO' : 'TOTAL_TOPICS_OTHER';
  32. // Grab group details for legend display
  33. if ($auth->acl_gets('a_group', 'a_groupadd', 'a_groupdel'))
  34. {
  35. $sql = 'SELECT group_id, group_name, group_colour, group_type
  36. FROM ' . GROUPS_TABLE . '
  37. WHERE group_legend = 1
  38. ORDER BY group_name ASC';
  39. }
  40. else
  41. {
  42. $sql = 'SELECT g.group_id, g.group_name, g.group_colour, g.group_type
  43. FROM ' . GROUPS_TABLE . ' g
  44. LEFT JOIN ' . USER_GROUP_TABLE . ' ug
  45. ON (
  46. g.group_id = ug.group_id
  47. AND ug.user_id = ' . $user->data['user_id'] . '
  48. AND ug.user_pending = 0
  49. )
  50. WHERE g.group_legend = 1
  51. AND (g.group_type <> ' . GROUP_HIDDEN . ' OR ug.user_id = ' . $user->data['user_id'] . ')
  52. ORDER BY g.group_name ASC';
  53. }
  54. $result = $db->sql_query($sql);
  55. $legend = '';
  56. while ($row = $db->sql_fetchrow($result))
  57. {
  58. $colour_text = ($row['group_colour']) ? ' style="color:#' . $row['group_colour'] . '"' : '';
  59. if ($row['group_name'] == 'BOTS')
  60. {
  61. $legend .= (($legend != '') ? ', ' : '') . '<span' . $colour_text . '>' . $user->lang['G_BOTS'] . '</span>';
  62. }
  63. else
  64. {
  65. // Begin SEO phpBB
  66. if ($user->data['user_id'] != ANONYMOUS && !$user->data['is_bot'] )
  67. {
  68. $legend .= (($legend != '') ? ', ' : '') . '<a' . $colour_text . ' href="' . append_sid("{$phpbb_root_path}memberlist.$phpEx", 'mode=group&amp;g=' . $row['group_id']) . '">' . (($row['group_type'] == GROUP_SPECIAL) ? $user->lang['G_' . $row['group_name']] : $row['group_name']) . '</a>';
  69. }
  70. else
  71. {
  72. $legend .= (($legend != '') ? ', ' : '') . '<span' . $colour_text . '>' . (($row['group_type'] == GROUP_SPECIAL) ? $user->lang['G_' . $row['group_name']] : $row['group_name']) . '</span>';
  73. }
  74. //$legend .= (($legend != '') ? ', ' : '') . '<a' . $colour_text . ' href="' . append_sid("{$phpbb_root_path}memberlist.$phpEx", 'mode=group&amp;g=' . $row['group_id']) . '">' . (($row['group_type'] == GROUP_SPECIAL) ? $user->lang['G_' . $row['group_name']] : $row['group_name']) . '</a>';
  75. // END SEO phpBB
  76. }
  77. }
  78. $db->sql_freeresult($result);
  79. // Generate birthday list if required ...
  80. $birthday_list = '';
  81. if ($config['load_birthdays'] && $config['allow_birthdays'])
  82. {
  83. $now = getdate(time() + $user->timezone + $user->dst - date('Z'));
  84. $sql = 'SELECT user_id, username, user_colour, user_birthday
  85. FROM ' . USERS_TABLE . "
  86. WHERE user_birthday LIKE '" . $db->sql_escape(sprintf('%2d-%2d-', $now['mday'], $now['mon'])) . "%'
  87. AND user_type IN (" . USER_NORMAL . ', ' . USER_FOUNDER . ')';
  88. $result = $db->sql_query($sql);
  89. while ($row = $db->sql_fetchrow($result))
  90. {
  91. $birthday_list .= (($birthday_list != '') ? ', ' : '') . get_username_string('full', $row['user_id'], $row['username'], $row['user_colour']);
  92. if ($age = (int) substr($row['user_birthday'], -4))
  93. {
  94. $birthday_list .= ' (' . ($now['year'] - $age) . ')';
  95. }
  96. }
  97. $db->sql_freeresult($result);
  98. }
  99. // Assign index specific vars
  100. $template->assign_vars(array(
  101. 'TOTAL_POSTS' => sprintf($user->lang[$l_total_post_s], $total_posts),
  102. 'TOTAL_TOPICS' => sprintf($user->lang[$l_total_topic_s], $total_topics),
  103. 'TOTAL_USERS' => sprintf($user->lang[$l_total_user_s], $total_users),
  104. 'NEWEST_USER' => sprintf($user->lang['NEWEST_USER'], get_username_string('full', $config['newest_user_id'], $config['newest_username'], $config['newest_user_colour'])),
  105. 'LEGEND' => $legend,
  106. 'BIRTHDAY_LIST' => $birthday_list,
  107. 'FORUM_IMG' => $user->img('forum_read', 'NO_NEW_POSTS'),
  108. 'FORUM_NEW_IMG' => $user->img('forum_unread', 'NEW_POSTS'),
  109. 'FORUM_LOCKED_IMG' => $user->img('forum_read_locked', 'NO_NEW_POSTS_LOCKED'),
  110. 'FORUM_NEW_LOCKED_IMG' => $user->img('forum_unread_locked', 'NO_NEW_POSTS_LOCKED'),
  111. 'S_LOGIN_ACTION' => append_sid("{$phpbb_root_path}ucp.$phpEx", 'mode=login'),
  112. 'S_DISPLAY_BIRTHDAY_LIST' => ($config['load_birthdays']) ? true : false,
  113. 'U_MARK_FORUMS' => ($user->data['is_registered'] || $config['load_anon_lastread']) ? append_sid("{$phpbb_root_path}index.$phpEx", 'mark=forums') : '',
  114. 'U_MCP' => ($auth->acl_get('m_') || $auth->acl_getf_global('m_')) ? append_sid("{$phpbb_root_path}mcp.$phpEx", 'i=main&amp;mode=front', true, $user->session_id) : '')
  115. );
  116. // Output page
  117. page_header($user->lang['INDEX']);
  118. $template->set_filenames(array(
  119. 'body' => 'index_body.html')
  120. );
  121. page_footer();
  122. ?>