2001-04-19 13:18:57 +00:00
|
|
|
<?php
|
|
|
|
/***************************************************************************
|
|
|
|
* functions.php
|
|
|
|
* -------------------
|
|
|
|
* begin : Saturday, Feb 13, 2001
|
|
|
|
* copyright : (C) 2001 The phpBB Group
|
|
|
|
* email : support@phpbb.com
|
|
|
|
*
|
|
|
|
* $Id$
|
|
|
|
*
|
|
|
|
***************************************************************************/
|
|
|
|
|
|
|
|
/***************************************************************************
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
***************************************************************************/
|
|
|
|
|
2002-11-07 03:20:33 +00:00
|
|
|
function sql_escape($msg)
|
2002-11-05 04:50:55 +00:00
|
|
|
{
|
|
|
|
return str_replace("'", "''", str_replace('\\', '\\\\', $msg));
|
|
|
|
}
|
|
|
|
|
2002-10-08 20:06:55 +00:00
|
|
|
function sql_quote($msg)
|
|
|
|
{
|
2002-10-28 20:38:53 +00:00
|
|
|
return str_replace("\'", "''", $msg);
|
2002-10-08 20:06:55 +00:00
|
|
|
}
|
|
|
|
|
2002-02-12 17:14:39 +00:00
|
|
|
function get_userdata($user)
|
2001-05-30 20:21:42 +00:00
|
|
|
{
|
|
|
|
global $db;
|
|
|
|
|
2001-06-11 00:58:08 +00:00
|
|
|
$sql = "SELECT *
|
2002-08-17 22:08:34 +00:00
|
|
|
FROM " . USERS_TABLE . "
|
2002-02-12 17:14:39 +00:00
|
|
|
WHERE ";
|
2002-11-18 18:56:27 +00:00
|
|
|
$sql .= ((is_int($user)) ? "user_id = $user" : "username = '" . sql_quote($user) . "'") . " AND user_id <> " . ANONYMOUS;
|
2002-07-14 14:35:12 +00:00
|
|
|
$result = $db->sql_query($sql);
|
2001-05-30 20:21:42 +00:00
|
|
|
|
2002-11-18 18:56:27 +00:00
|
|
|
return ($row = $db->sql_fetchrow($result)) ? $row : false;
|
2001-05-30 20:21:42 +00:00
|
|
|
}
|
2001-04-19 13:18:57 +00:00
|
|
|
|
2002-10-30 00:57:27 +00:00
|
|
|
function get_forum_branch($forum_id, $type = 'all', $order = 'descending', $include_forum = TRUE)
|
2002-09-15 17:21:08 +00:00
|
|
|
{
|
|
|
|
global $db;
|
|
|
|
|
|
|
|
switch ($type)
|
|
|
|
{
|
|
|
|
case 'parents':
|
|
|
|
$condition = 'f1.left_id BETWEEN f2.left_id AND f2.right_id';
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'children':
|
|
|
|
$condition = 'f2.left_id BETWEEN f1.left_id AND f1.right_id';
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
$condition = 'f2.left_id BETWEEN f1.left_id AND f1.right_id OR f1.left_id BETWEEN f2.left_id AND f2.right_id';
|
|
|
|
}
|
|
|
|
|
|
|
|
$rows = array();
|
2002-10-20 19:19:07 +00:00
|
|
|
|
|
|
|
$sql = 'SELECT f2.*
|
2002-11-18 18:56:27 +00:00
|
|
|
FROM (' . FORUMS_TABLE . ' f1
|
|
|
|
LEFT JOIN ' . FORUMS_TABLE . " f2 ON $condition)
|
2002-10-20 19:19:07 +00:00
|
|
|
WHERE f1.forum_id = $forum_id
|
2002-11-18 18:56:27 +00:00
|
|
|
ORDER BY f2.left_id " . (($order == 'descending') ? 'ASC' : 'DESC');
|
2002-09-15 17:21:08 +00:00
|
|
|
$result = $db->sql_query($sql);
|
2002-10-20 19:19:07 +00:00
|
|
|
|
2002-09-15 17:21:08 +00:00
|
|
|
while ($row = $db->sql_fetchrow($result))
|
|
|
|
{
|
|
|
|
if (!$include_forum && $row['forum_id'] == $forum_id)
|
|
|
|
{
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
$rows[] = $row;
|
|
|
|
}
|
|
|
|
return $rows;
|
|
|
|
}
|
|
|
|
|
2002-11-19 18:55:23 +00:00
|
|
|
// Create forum navigation links for given forum, create parent
|
|
|
|
// list if currently null, assign basic forum info to template
|
|
|
|
function generate_forum_nav(&$forum_data)
|
|
|
|
{
|
|
|
|
global $db, $user, $template;
|
|
|
|
|
|
|
|
// Get forum parents
|
|
|
|
$forum_parents = array();
|
|
|
|
if ($forum_data['parent_id'] > 0)
|
|
|
|
{
|
|
|
|
if (empty($forum_data['forum_parents']))
|
|
|
|
{
|
|
|
|
$sql = 'SELECT forum_id, forum_name
|
|
|
|
FROM ' . FORUMS_TABLE . '
|
|
|
|
WHERE left_id < ' . $forum_data['left_id'] . '
|
|
|
|
AND right_id > ' . $forum_data['right_id'] . '
|
|
|
|
ORDER BY left_id ASC';
|
|
|
|
|
|
|
|
$result = $db->sql_query($sql);
|
|
|
|
while ($row = $db->sql_fetchrow($result))
|
|
|
|
{
|
|
|
|
$forum_parents[$row['forum_id']] = $row['forum_name'];
|
|
|
|
}
|
|
|
|
|
|
|
|
$sql = 'UPDATE ' . FORUMS_TABLE . "
|
|
|
|
SET forum_parents = '" . sql_escape(serialize($forum_parents)) . "'
|
|
|
|
WHERE parent_id = " . $forum_data['parent_id'];
|
|
|
|
$db->sql_query($sql);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
$forum_parents = unserialize($forum_data['forum_parents']);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Build navigation links
|
|
|
|
foreach ($forum_parents as $parent_forum_id => $parent_name)
|
|
|
|
{
|
|
|
|
$template->assign_block_vars('navlinks', array(
|
|
|
|
'FORUM_NAME' => $parent_name,
|
|
|
|
'U_VIEW_FORUM' => 'viewforum.' . $phpEx . $SID . '&f=' . $parent_forum_id
|
|
|
|
));
|
|
|
|
}
|
|
|
|
$template->assign_block_vars('navlinks', array(
|
|
|
|
'FORUM_NAME' => $forum_data['forum_name'],
|
|
|
|
'U_VIEW_FORUM' => 'viewforum.' . $phpEx . $SID . '&f=' . $forum_id
|
|
|
|
));
|
|
|
|
|
|
|
|
$template->assign_vars(array(
|
|
|
|
'FORUM_ID' => $forum_id,
|
|
|
|
'FORUM_NAME' => $forum_data['forum_name'],
|
|
|
|
'FORUM_DESC' => strip_tags($forum_data['forum_desc'])
|
|
|
|
));
|
|
|
|
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2002-07-14 14:35:12 +00:00
|
|
|
// Obtain list of moderators of each forum
|
|
|
|
function get_moderators(&$forum_moderators, $forum_id = false)
|
2001-04-19 13:18:57 +00:00
|
|
|
{
|
2002-10-26 12:34:39 +00:00
|
|
|
global $SID, $db, $acl_options, $phpEx;
|
2002-07-14 14:35:12 +00:00
|
|
|
|
2002-11-18 18:56:27 +00:00
|
|
|
if (!empty($forum_id) && is_array($forum_id))
|
2002-11-07 03:20:33 +00:00
|
|
|
{
|
2002-11-18 18:56:27 +00:00
|
|
|
$forum_sql = 'AND forum_id IN (' . implode(', ', $forum_id) . ')';
|
2002-11-07 03:20:33 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2002-11-18 18:56:27 +00:00
|
|
|
$forum_sql = ($forum_id) ? 'AND forum_id = ' . $forum_id : '';
|
2002-11-07 03:20:33 +00:00
|
|
|
}
|
2002-11-18 18:56:27 +00:00
|
|
|
|
|
|
|
$sql = 'SELECT *
|
|
|
|
FROM ' . MODERATOR_TABLE . "
|
|
|
|
WHERE display_on_index = 1
|
2002-10-28 00:25:38 +00:00
|
|
|
$forum_sql";
|
|
|
|
$result = $db->sql_query($sql);
|
|
|
|
|
2002-11-18 18:56:27 +00:00
|
|
|
while ($row = $db->sql_fetchrow($result))
|
2002-10-28 00:25:38 +00:00
|
|
|
{
|
2002-11-18 18:56:27 +00:00
|
|
|
$forum_moderators[$row['forum_id']][] = (!empty($row['user_id'])) ? '<a href="profile.' . $phpEx . $SID . '&mode=viewprofile&u=' . $row['user_id'] . '">' . $row['username'] . '</a>' : '<a href="groupcp.' . $phpEx . $SID . '&g=' . $row['group_id'] . '">' . $row['groupname'] . '</a>';
|
|
|
|
}
|
|
|
|
$db->sql_freeresult($result);
|
2002-07-14 14:35:12 +00:00
|
|
|
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// User authorisation levels output
|
|
|
|
function get_forum_rules($mode, &$rules, &$forum_id)
|
|
|
|
{
|
2002-10-30 00:57:27 +00:00
|
|
|
global $SID, $auth, $user;
|
2002-07-14 14:35:12 +00:00
|
|
|
|
2002-11-18 18:56:27 +00:00
|
|
|
$rules .= (($auth->acl_gets('f_post', 'm_', 'a_', $forum_id)) ? $user->lang['Rules_post_can'] : $user->lang['Rules_post_cannot']) . '<br />';
|
|
|
|
$rules .= (($auth->acl_gets('f_reply', 'm_', 'a_', $forum_id)) ? $user->lang['Rules_reply_can'] : $user->lang['Rules_reply_cannot']) . '<br />';
|
|
|
|
$rules .= (($auth->acl_gets('f_edit', 'm_', 'a_', $forum_id)) ? $user->lang['Rules_edit_can'] : $user->lang['Rules_edit_cannot']) . '<br />';
|
|
|
|
$rules .= (($auth->acl_gets('f_delete', 'm_', 'a_', $forum_id) || $auth->acl_get('m_delete', $forum_id)) ? $user->lang['Rules_delete_can'] : $user->lang['Rules_delete_cannot']) . '<br />';
|
|
|
|
$rules .= (($auth->acl_gets('f_attach', 'm_', 'a_', $forum_id)) ? $user->lang['Rules_attach_can'] : $user->lang['Rules_attach_cannot']) . '<br />';
|
2001-04-19 13:18:57 +00:00
|
|
|
|
2002-07-14 14:35:12 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2002-10-08 20:06:55 +00:00
|
|
|
function make_jumpbox($action, $forum_id = false)
|
2002-07-14 14:35:12 +00:00
|
|
|
{
|
2002-10-20 19:19:07 +00:00
|
|
|
global $auth, $template, $user, $db, $nav_links, $phpEx;
|
2002-07-14 14:35:12 +00:00
|
|
|
|
2002-11-19 23:12:11 +00:00
|
|
|
$boxstring = '<select name="f" onChange="if(this.options[this.selectedIndex].value != -1){ forms[\'jumpbox\'].submit() }"><option value="-1">' . $user->lang['Select_forum'] . '</option><option value="-1">-----------------</option>';
|
2002-10-10 00:35:35 +00:00
|
|
|
|
2002-11-19 23:12:11 +00:00
|
|
|
$sql = 'SELECT forum_id, forum_name, forum_postable, forum_status, left_id, right_id
|
2002-10-10 00:35:35 +00:00
|
|
|
FROM ' . FORUMS_TABLE . '
|
|
|
|
ORDER BY left_id ASC';
|
2002-10-08 20:06:55 +00:00
|
|
|
$result = $db->sql_query($sql);
|
2002-02-12 17:14:39 +00:00
|
|
|
|
2002-11-19 23:12:11 +00:00
|
|
|
$right = $cat_right = 0;
|
|
|
|
$padding = $forum_list = '';
|
2002-11-18 18:56:27 +00:00
|
|
|
while ($row = $db->sql_fetchrow($result))
|
2002-07-14 14:35:12 +00:00
|
|
|
{
|
2002-11-19 23:12:11 +00:00
|
|
|
if (!$row['forum_postable'] && ($row['left_id'] + 1 == $row['right_id']))
|
|
|
|
{
|
|
|
|
// Non-postable forum with no subforums, don't display
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!$auth->acl_gets('f_list', 'm_', 'a_', intval($row['forum_id'])))
|
|
|
|
{
|
|
|
|
// if the user does not have permissions to list this forum skip
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($row['left_id'] < $right)
|
2002-10-10 00:35:35 +00:00
|
|
|
{
|
|
|
|
$padding .= ' ';
|
|
|
|
}
|
2002-11-18 18:56:27 +00:00
|
|
|
else if ($row['left_id'] > $right + 1)
|
2002-10-10 00:35:35 +00:00
|
|
|
{
|
2002-11-18 18:56:27 +00:00
|
|
|
$padding = substr($padding, 0, -13 * ($row['left_id'] - $right + 1));
|
2002-10-10 00:35:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
$right = $row['right_id'];
|
|
|
|
|
2002-11-19 23:12:11 +00:00
|
|
|
$selected = ($row['forum_id'] == $forum_id) ? ' selected="selected"' : '';
|
2001-12-05 00:50:12 +00:00
|
|
|
|
2002-11-19 23:12:11 +00:00
|
|
|
if ($row['left_id'] > $cat_right)
|
|
|
|
{
|
|
|
|
$holding = '';
|
|
|
|
}
|
2002-10-11 02:55:34 +00:00
|
|
|
|
2002-11-19 23:12:11 +00:00
|
|
|
if ($row['forum_status'] == ITEM_CATEGORY)
|
|
|
|
{
|
|
|
|
$cat_right = max($cat_right, $row['right_id']);
|
2001-10-14 15:48:38 +00:00
|
|
|
|
2002-11-19 23:12:11 +00:00
|
|
|
$holding .= '<option value="' . $row['forum_id'] . '"' . $selected . '>' . $padding . '+ ' . $row['forum_name'] . '</option>';
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
$boxstring .= $holding . '<option value="' . $row['forum_id'] . '"' . $selected . '>' . $padding . '- ' . $row['forum_name'] . '</option>';
|
|
|
|
$holding = '';
|
2002-10-08 20:06:55 +00:00
|
|
|
}
|
2002-10-10 00:35:35 +00:00
|
|
|
|
2002-11-19 23:12:11 +00:00
|
|
|
$nav_links['chapter forum'][$row['forum_id']] = array (
|
|
|
|
'url' => ($row['forum_status'] == ITEM_CATEGORY) ? "index.$phpEx$SIDc=" : "viewforum.$phpEx$SID&f=" . $row['forum_id'],
|
|
|
|
'title' => $row['forum_name']
|
|
|
|
);
|
2002-10-08 20:06:55 +00:00
|
|
|
}
|
|
|
|
$db->sql_freeresult($result);
|
2002-10-10 00:35:35 +00:00
|
|
|
|
|
|
|
if (!$right)
|
|
|
|
{
|
2002-10-20 19:19:07 +00:00
|
|
|
$boxstring .= '<option value="-1">' . $user->lang['No_forums'] . '</option>';
|
2002-10-10 00:35:35 +00:00
|
|
|
}
|
|
|
|
$boxstring .= '</select>';
|
|
|
|
|
2002-03-31 00:06:34 +00:00
|
|
|
$template->assign_vars(array(
|
2002-10-20 19:19:07 +00:00
|
|
|
'L_GO' => $user->lang['Go'],
|
|
|
|
'L_JUMP_TO' => $user->lang['Jump_to'],
|
2002-03-31 00:06:34 +00:00
|
|
|
|
|
|
|
'S_JUMPBOX_SELECT' => $boxstring,
|
2002-07-14 14:35:12 +00:00
|
|
|
'S_JUMPBOX_ACTION' => $action)
|
2002-03-31 00:06:34 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
return;
|
2001-04-19 13:18:57 +00:00
|
|
|
}
|
|
|
|
|
2002-07-14 14:35:12 +00:00
|
|
|
// Pick a language, any language ...
|
|
|
|
function language_select($default, $select_name = "language", $dirname="language")
|
2001-04-19 13:18:57 +00:00
|
|
|
{
|
2002-07-14 14:35:12 +00:00
|
|
|
global $phpEx;
|
|
|
|
|
2002-10-30 00:57:27 +00:00
|
|
|
$dir = @opendir($dirname);
|
2001-05-02 00:42:33 +00:00
|
|
|
|
2002-10-20 19:19:07 +00:00
|
|
|
$user = array();
|
2002-11-18 18:56:27 +00:00
|
|
|
while ($file = readdir($dir))
|
2001-04-19 13:18:57 +00:00
|
|
|
{
|
2002-10-31 03:20:54 +00:00
|
|
|
if (!is_dir($dirname . '/' . $file))
|
|
|
|
{
|
|
|
|
continue;
|
|
|
|
}
|
2002-11-18 18:56:27 +00:00
|
|
|
if (@file_exists($dirname . '/' . $file . '/iso.txt'))
|
2001-06-11 12:53:35 +00:00
|
|
|
{
|
2002-10-28 00:34:43 +00:00
|
|
|
list($displayname) = file($dirname . '/' . $file . '/iso.txt');
|
2002-10-31 03:20:54 +00:00
|
|
|
$lang[$displayname] = $file;
|
2001-06-11 12:53:35 +00:00
|
|
|
}
|
2002-07-14 14:35:12 +00:00
|
|
|
}
|
2002-10-30 00:57:27 +00:00
|
|
|
@closedir($dir);
|
2001-07-08 20:24:15 +00:00
|
|
|
|
2002-10-30 00:57:27 +00:00
|
|
|
@asort($lang);
|
|
|
|
@reset($lang);
|
2001-07-14 17:30:21 +00:00
|
|
|
|
2002-10-20 19:19:07 +00:00
|
|
|
$user_select = '<select name="' . $select_name . '">';
|
2002-11-18 18:56:27 +00:00
|
|
|
foreach ($lang as $displayname => $filename)
|
2001-04-19 13:18:57 +00:00
|
|
|
{
|
2002-11-18 18:56:27 +00:00
|
|
|
$selected = (strtolower($default) == strtolower($filename)) ? ' selected="selected"' : '';
|
2002-10-20 19:19:07 +00:00
|
|
|
$user_select .= '<option value="' . $filename . '"' . $selected . '>' . ucwords($displayname) . '</option>';
|
2001-04-19 13:18:57 +00:00
|
|
|
}
|
2002-10-20 19:19:07 +00:00
|
|
|
$user_select .= '</select>';
|
2001-05-03 22:10:23 +00:00
|
|
|
|
2002-10-20 19:19:07 +00:00
|
|
|
return $user_select;
|
2002-07-14 14:35:12 +00:00
|
|
|
}
|
2001-12-14 02:41:33 +00:00
|
|
|
|
2002-08-17 22:08:34 +00:00
|
|
|
// Pick a template/theme combo,
|
2002-10-20 19:19:07 +00:00
|
|
|
function style_select($default_style, $select_name = 'style', $dirname = 'templates')
|
2002-07-14 14:35:12 +00:00
|
|
|
{
|
|
|
|
global $db;
|
2001-12-14 02:41:33 +00:00
|
|
|
|
2002-07-14 14:35:12 +00:00
|
|
|
$sql = "SELECT style_id, style_name
|
2002-08-17 22:08:34 +00:00
|
|
|
FROM " . STYLES_TABLE . "
|
2002-07-14 14:35:12 +00:00
|
|
|
ORDER BY style_name, style_id";
|
|
|
|
$result = $db->sql_query($sql);
|
2001-12-14 02:41:33 +00:00
|
|
|
|
2002-07-14 14:35:12 +00:00
|
|
|
$style_select = '<select name="' . $select_name . '">';
|
2002-11-18 18:56:27 +00:00
|
|
|
while ($row = $db->sql_fetchrow($result))
|
2001-12-14 02:41:33 +00:00
|
|
|
{
|
2002-11-18 18:56:27 +00:00
|
|
|
$selected = ($row['style_id'] == $default_style) ? ' selected="selected"' : '';
|
2001-11-16 17:31:49 +00:00
|
|
|
|
2002-07-14 14:35:12 +00:00
|
|
|
$style_select .= '<option value="' . $row['style_id'] . '"' . $selected . '>' . $row['style_name'] . '</option>';
|
|
|
|
}
|
|
|
|
$style_select .= "</select>";
|
2002-02-08 01:33:36 +00:00
|
|
|
|
2002-07-14 14:35:12 +00:00
|
|
|
return $style_select;
|
2001-04-19 13:18:57 +00:00
|
|
|
}
|
2001-05-01 19:10:09 +00:00
|
|
|
|
2002-07-14 14:35:12 +00:00
|
|
|
// Pick a timezone
|
|
|
|
function tz_select($default, $select_name = 'timezone')
|
2001-04-19 13:18:57 +00:00
|
|
|
{
|
2002-10-20 19:19:07 +00:00
|
|
|
global $sys_timezone, $user;
|
2001-05-03 22:10:23 +00:00
|
|
|
|
2002-07-14 14:35:12 +00:00
|
|
|
$tz_select = '<select name="' . $select_name . '">';
|
2002-11-18 18:56:27 +00:00
|
|
|
foreach ($user->lang['tz'] as $offset => $zone)
|
2001-05-01 19:10:09 +00:00
|
|
|
{
|
2002-11-18 18:56:27 +00:00
|
|
|
$selected = ($offset == $default) ? ' selected="selected"' : '';
|
2002-07-14 14:35:12 +00:00
|
|
|
$tz_select .= '<option value="' . $offset . '"' . $selected . '>' . $zone . '</option>';
|
2001-05-01 19:10:09 +00:00
|
|
|
}
|
2002-07-14 14:35:12 +00:00
|
|
|
$tz_select .= '</select>';
|
2001-09-25 18:18:47 +00:00
|
|
|
|
2002-07-14 14:35:12 +00:00
|
|
|
return $tz_select;
|
|
|
|
}
|
2001-09-25 18:18:47 +00:00
|
|
|
|
2002-07-14 14:35:12 +00:00
|
|
|
// Topic and forum watching common code
|
2002-11-05 04:50:55 +00:00
|
|
|
function watch_topic_forum($mode, &$s_watching, &$s_watching_img, $user_id, $match_id, $notify_status = 'unset')
|
2002-07-14 14:35:12 +00:00
|
|
|
{
|
2002-10-20 19:19:07 +00:00
|
|
|
global $template, $db, $user, $phpEx, $SID, $start;
|
2001-09-25 18:18:47 +00:00
|
|
|
|
2002-11-18 18:56:27 +00:00
|
|
|
$table_sql = ($mode == 'forum') ? FORUMS_WATCH_TABLE : TOPICS_WATCH_TABLE;
|
|
|
|
$where_sql = ($mode == 'forum') ? 'forum_id' : 'topic_id';
|
|
|
|
$u_url = ($mode == 'forum') ? 'f' : 't';
|
2001-09-25 18:18:47 +00:00
|
|
|
|
2002-08-17 22:08:34 +00:00
|
|
|
// Is user watching this thread?
|
2002-11-18 18:56:27 +00:00
|
|
|
if ($user_id)
|
2001-09-25 18:18:47 +00:00
|
|
|
{
|
2002-07-14 14:35:12 +00:00
|
|
|
$can_watch = TRUE;
|
2001-09-25 18:18:47 +00:00
|
|
|
|
2002-11-05 04:50:55 +00:00
|
|
|
if ($notify_status == 'unset')
|
|
|
|
{
|
|
|
|
$sql = "SELECT notify_status
|
|
|
|
FROM $table_sql
|
|
|
|
WHERE $where_sql = $match_id
|
|
|
|
AND user_id = $user_id";
|
|
|
|
$result = $db->sql_query($sql);
|
|
|
|
|
|
|
|
if ($row = $db->sql_fetchrow($result))
|
|
|
|
{
|
|
|
|
$notify_status = $row['notify_status'];
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
$notify_status = NULL;
|
|
|
|
}
|
|
|
|
}
|
2002-07-14 14:35:12 +00:00
|
|
|
|
2002-11-05 04:50:55 +00:00
|
|
|
if (!is_null($notify_status))
|
2001-09-25 18:18:47 +00:00
|
|
|
{
|
2002-11-18 18:56:27 +00:00
|
|
|
if (isset($_GET['unwatch']))
|
2002-07-14 14:35:12 +00:00
|
|
|
{
|
2002-11-18 18:56:27 +00:00
|
|
|
if ($_GET['unwatch'] == $mode)
|
2002-07-14 14:35:12 +00:00
|
|
|
{
|
|
|
|
$is_watching = 0;
|
|
|
|
|
|
|
|
$sql = "DELETE FROM " . $table_sql . "
|
2002-08-17 22:08:34 +00:00
|
|
|
WHERE $where_sql = $match_id
|
2002-07-14 14:35:12 +00:00
|
|
|
AND user_id = $user_id";
|
|
|
|
$db->sql_query($sql);
|
|
|
|
}
|
2002-08-17 22:08:34 +00:00
|
|
|
|
2002-07-14 14:35:12 +00:00
|
|
|
$template->assign_vars(array(
|
|
|
|
'META' => '<meta http-equiv="refresh" content="3;url=' . "view$mode.$phpEx$SID&" . $u_url . "=$match_id&start=$start" . '">')
|
|
|
|
);
|
|
|
|
|
2002-10-20 19:19:07 +00:00
|
|
|
$message = $user->lang['No_longer_watching_' . $mode] . '<br /><br />' . sprintf($user->lang['Click_return_' . $mode], '<a href="' . "view$mode.$phpEx$SID&" . $u_url . "=$match_id&start=$start" . '">', '</a>');
|
2002-10-30 00:57:27 +00:00
|
|
|
trigger_error($message);
|
2002-07-14 14:35:12 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
$is_watching = TRUE;
|
|
|
|
|
2002-11-05 04:50:55 +00:00
|
|
|
if ($notify_status)
|
2002-07-14 14:35:12 +00:00
|
|
|
{
|
|
|
|
$sql = "UPDATE " . $table_sql . "
|
|
|
|
SET notify_status = 0
|
|
|
|
WHERE $where_sql = $match_id
|
|
|
|
AND user_id = $user_id";
|
|
|
|
$db->sql_query($sql);
|
|
|
|
}
|
|
|
|
}
|
2001-09-25 18:18:47 +00:00
|
|
|
}
|
2002-07-14 14:35:12 +00:00
|
|
|
else
|
|
|
|
{
|
2002-11-18 18:56:27 +00:00
|
|
|
if (isset($_GET['watch']))
|
2002-07-14 14:35:12 +00:00
|
|
|
{
|
2002-11-18 18:56:27 +00:00
|
|
|
if ($_GET['watch'] == $mode)
|
2002-07-14 14:35:12 +00:00
|
|
|
{
|
|
|
|
$is_watching = TRUE;
|
2001-09-25 18:18:47 +00:00
|
|
|
|
2002-07-14 14:35:12 +00:00
|
|
|
$sql = "INSERT INTO " . $table_sql . " (user_id, $where_sql, notify_status)
|
|
|
|
VALUES ($user_id, $match_id, 0)";
|
|
|
|
$db->sql_query($sql);
|
|
|
|
}
|
|
|
|
|
|
|
|
$template->assign_vars(array(
|
|
|
|
'META' => '<meta http-equiv="refresh" content="3;url=' . "view$mode.$phpEx$SID&" . $u_url . "=$match_id&start=$start" . '">')
|
|
|
|
);
|
2002-02-25 14:59:01 +00:00
|
|
|
|
2002-10-20 19:19:07 +00:00
|
|
|
$message = $user->lang['You_are_watching_' . $mode] . '<br /><br />' . sprintf($user->lang['Click_return_' . $mode], '<a href="' . "view$mode.$phpEx$SID&" . $u_url . "=$match_id&start=$start" . '">', '</a>');
|
2002-10-30 00:57:27 +00:00
|
|
|
trigger_error($message);
|
2002-07-14 14:35:12 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
$is_watching = 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2002-11-18 18:56:27 +00:00
|
|
|
if (isset($_GET['unwatch']))
|
2002-02-04 18:31:22 +00:00
|
|
|
{
|
2002-11-18 18:56:27 +00:00
|
|
|
if ($_GET['unwatch'] == $mode)
|
2002-03-18 13:35:23 +00:00
|
|
|
{
|
2002-10-09 19:50:48 +00:00
|
|
|
redirect("login.$phpEx$SID&redirect=view$mode.$phpEx&" . $u_url . "=$match_id&unwatch=forum");
|
2002-03-18 13:35:23 +00:00
|
|
|
}
|
2002-02-04 18:31:22 +00:00
|
|
|
}
|
2002-07-14 14:35:12 +00:00
|
|
|
else
|
|
|
|
{
|
|
|
|
$can_watch = 0;
|
|
|
|
$is_watching = 0;
|
|
|
|
}
|
2001-09-25 18:18:47 +00:00
|
|
|
}
|
|
|
|
|
2002-11-18 18:56:27 +00:00
|
|
|
if ($can_watch)
|
2002-07-14 14:35:12 +00:00
|
|
|
{
|
2002-11-18 18:56:27 +00:00
|
|
|
$s_watching = ($is_watching) ? '<a href="' . "view$mode." . $phpEx . $SID . '&' . $u_url . "=$match_id&unwatch=$mode&start=$start" . '">' . $user->lang['Stop_watching_' . $mode] . '</a>' : '<a href="' . "view$mode." . $phpEx . $SID . '&' . $u_url . "=$match_id&watch=$mode&start=$start" . '">' . $user->lang['Start_watching_' . $mode] . '</a>';
|
2002-07-14 14:35:12 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return;
|
2001-04-19 13:18:57 +00:00
|
|
|
}
|
|
|
|
|
2002-10-20 19:19:07 +00:00
|
|
|
// Pagination routine, generates page number sequence
|
2001-05-07 23:04:16 +00:00
|
|
|
function generate_pagination($base_url, $num_items, $per_page, $start_item, $add_prevnext_text = TRUE)
|
|
|
|
{
|
2002-10-20 19:19:07 +00:00
|
|
|
global $user;
|
2001-05-27 03:11:27 +00:00
|
|
|
|
2001-05-07 23:04:16 +00:00
|
|
|
$total_pages = ceil($num_items/$per_page);
|
2001-10-25 23:21:12 +00:00
|
|
|
|
2002-11-18 18:56:27 +00:00
|
|
|
if ($total_pages == 1 || !$num_items)
|
2001-05-07 23:04:16 +00:00
|
|
|
{
|
2002-04-02 14:04:18 +00:00
|
|
|
return '';
|
2001-05-07 23:04:16 +00:00
|
|
|
}
|
|
|
|
|
2001-10-25 23:21:12 +00:00
|
|
|
$on_page = floor($start_item / $per_page) + 1;
|
2001-05-07 23:04:16 +00:00
|
|
|
|
2002-11-18 18:56:27 +00:00
|
|
|
$page_string = ($on_page == 1) ? '<b>1</b>' : '<a href="' . $base_url . "&start=" . (($on_page - 2) * $per_page) . '">' . $user->lang['Previous'] . '</a> <a href="' . $base_url . '">1</a>';
|
2002-10-04 13:09:10 +00:00
|
|
|
|
2002-11-18 18:56:27 +00:00
|
|
|
if ($total_pages > 5)
|
2001-05-07 23:04:16 +00:00
|
|
|
{
|
2002-10-04 13:09:10 +00:00
|
|
|
$start_cnt = min(max(1, $on_page - 4), $total_pages - 5);
|
|
|
|
$end_cnt = max(min($total_pages, $on_page + 4), 6);
|
|
|
|
|
2002-11-18 18:56:27 +00:00
|
|
|
$page_string .= ($start_cnt > 1) ? ' ... ' : ', ';
|
2001-10-25 23:21:12 +00:00
|
|
|
|
2002-10-04 13:09:10 +00:00
|
|
|
for($i = $start_cnt + 1; $i < $end_cnt; $i++)
|
2001-05-07 23:04:16 +00:00
|
|
|
{
|
2002-11-18 18:56:27 +00:00
|
|
|
$page_string .= ($i == $on_page) ? '<b>' . $i . '</b>' : '<a href="' . $base_url . "&start=" . (($i - 1) * $per_page) . '">' . $i . '</a>';
|
|
|
|
if ($i < $end_cnt - 1)
|
2001-10-25 23:21:12 +00:00
|
|
|
{
|
2002-10-04 13:09:10 +00:00
|
|
|
$page_string .= ', ';
|
2001-10-25 23:21:12 +00:00
|
|
|
}
|
2001-05-07 23:04:16 +00:00
|
|
|
}
|
|
|
|
|
2002-11-18 18:56:27 +00:00
|
|
|
$page_string .= ($end_cnt < $total_pages) ? ' ... ' : ', ';
|
2001-10-25 23:21:12 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2002-10-04 13:09:10 +00:00
|
|
|
$page_string .= ', ';
|
|
|
|
|
|
|
|
for($i = 2; $i < $total_pages; $i++)
|
2001-10-25 23:21:12 +00:00
|
|
|
{
|
2002-11-18 18:56:27 +00:00
|
|
|
$page_string .= ($i == $on_page) ? '<b>' . $i . '</b>' : '<a href="' . $base_url . "&start=" . (($i - 1) * $per_page) . '">' . $i . '</a>';
|
|
|
|
if ($i < $total_pages)
|
2001-10-25 23:21:12 +00:00
|
|
|
{
|
2002-02-08 01:33:36 +00:00
|
|
|
$page_string .= ', ';
|
2001-10-25 23:21:12 +00:00
|
|
|
}
|
|
|
|
}
|
2001-05-07 23:04:16 +00:00
|
|
|
}
|
2001-05-27 03:11:27 +00:00
|
|
|
|
2002-11-18 18:56:27 +00:00
|
|
|
$page_string .= ($on_page == $total_pages) ? '<b>' . $total_pages . '</b>' : '<a href="' . $base_url . '&start=' . (($total_pages - 1) * $per_page) . '">' . $total_pages . '</a> <a href="' . $base_url . "&start=" . ($on_page * $per_page) . '">' . $user->lang['Next'] . '</a>';
|
2001-05-07 23:04:16 +00:00
|
|
|
|
2002-10-20 19:19:07 +00:00
|
|
|
$page_string = $user->lang['Goto_page'] . ' ' . $page_string;
|
2001-10-25 23:21:12 +00:00
|
|
|
|
2001-05-07 23:04:16 +00:00
|
|
|
return $page_string;
|
|
|
|
}
|
|
|
|
|
2002-08-02 16:39:02 +00:00
|
|
|
function on_page($num_items, $per_page, $start)
|
|
|
|
{
|
2002-10-20 19:19:07 +00:00
|
|
|
global $user;
|
2002-08-02 16:39:02 +00:00
|
|
|
|
2002-11-18 18:56:27 +00:00
|
|
|
return sprintf($user->lang['Page_of'], floor($start / $per_page) + 1, max(ceil($num_items / $per_page), 1));
|
2002-08-02 16:39:02 +00:00
|
|
|
}
|
|
|
|
|
2001-09-09 23:22:29 +00:00
|
|
|
// Obtain list of naughty words and build preg style replacement arrays for use by the
|
|
|
|
// calling script, note that the vars are passed as references this just makes it easier
|
|
|
|
// to return both sets of arrays
|
2001-09-02 22:08:01 +00:00
|
|
|
function obtain_word_list(&$orig_word, &$replacement_word)
|
|
|
|
{
|
|
|
|
global $db;
|
|
|
|
|
|
|
|
$sql = "SELECT word, replacement
|
|
|
|
FROM " . WORDS_TABLE;
|
2002-07-14 14:35:12 +00:00
|
|
|
$result = $db->sql_query($sql);
|
2002-02-08 01:44:27 +00:00
|
|
|
|
2002-11-18 18:56:27 +00:00
|
|
|
while ($row = $db->sql_fetchrow($result))
|
2001-09-02 22:08:01 +00:00
|
|
|
{
|
2002-10-20 19:19:07 +00:00
|
|
|
$orig_word[] = '#\b(' . str_replace('\*', '\w*?', preg_quote($row['word'], '#')) . ')\b#i';
|
|
|
|
$replacement_word[] = $row['replacement'];
|
2001-09-02 22:08:01 +00:00
|
|
|
}
|
|
|
|
|
2002-02-08 01:33:36 +00:00
|
|
|
return true;
|
2001-09-02 22:08:01 +00:00
|
|
|
}
|
|
|
|
|
2002-10-09 19:50:48 +00:00
|
|
|
// Redirects the user to another page then exits the script nicely
|
|
|
|
function redirect($location)
|
|
|
|
{
|
|
|
|
global $db;
|
2002-10-20 19:19:07 +00:00
|
|
|
|
2002-10-10 00:35:35 +00:00
|
|
|
if (isset($db))
|
|
|
|
{
|
|
|
|
$db->sql_close();
|
|
|
|
}
|
2002-10-09 19:50:48 +00:00
|
|
|
|
|
|
|
$header_location = (@preg_match('/Microsoft|WebSTAR|Xitami/', getenv('SERVER_SOFTWARE'))) ? 'Refresh: 0; URL=' : 'Location: ';
|
|
|
|
header($header_location . $location);
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
2002-10-30 00:57:27 +00:00
|
|
|
// Check to see if the username has been taken, or if it is disallowed.
|
|
|
|
// Also checks if it includes the " character, which we don't allow in usernames.
|
|
|
|
// Used for registering, changing names, and posting anonymously with a username
|
|
|
|
function validate_username($username)
|
|
|
|
{
|
|
|
|
global $db, $user;
|
|
|
|
|
|
|
|
$username = sql_quote($username);
|
|
|
|
|
|
|
|
$sql = "SELECT username
|
|
|
|
FROM " . USERS_TABLE . "
|
|
|
|
WHERE LOWER(username) = '" . strtolower($username) . "'";
|
|
|
|
$result = $db->sql_query($sql);
|
|
|
|
|
|
|
|
if (($row = $db->sql_fetchrow($result)) && $row['username'] != $user->data['username'])
|
|
|
|
{
|
|
|
|
return $user->lang['Username_taken'];
|
|
|
|
}
|
|
|
|
|
|
|
|
$sql = "SELECT group_name
|
|
|
|
FROM " . GROUPS_TABLE . "
|
|
|
|
WHERE LOWER(group_name) = '" . strtolower($username) . "'";
|
|
|
|
$result = $db->sql_query($sql);
|
|
|
|
|
|
|
|
if ($row = $db->sql_fetchrow($result))
|
|
|
|
{
|
|
|
|
return $user->lang['Username_taken'];
|
|
|
|
}
|
|
|
|
|
|
|
|
$sql = "SELECT disallow_username
|
|
|
|
FROM " . DISALLOW_TABLE;
|
|
|
|
$result = $db->sql_query($sql);
|
|
|
|
|
|
|
|
while ($row = $db->sql_fetchrow($result))
|
|
|
|
{
|
|
|
|
if (preg_match('#\b(' . str_replace('\*', '.*?', preg_quote($row['disallow_username'])) . ')\b#i', $username))
|
|
|
|
{
|
|
|
|
return $user->lang['Username_disallowed'];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$sql = "SELECT word
|
|
|
|
FROM " . WORDS_TABLE;
|
|
|
|
$result = $db->sql_query($sql);
|
|
|
|
|
|
|
|
while ($row = $db->sql_fetchrow($result))
|
|
|
|
{
|
|
|
|
if (preg_match('#\b(' . str_replace('\*', '.*?', preg_quote($row['word'])) . ')\b#i', $username))
|
|
|
|
{
|
|
|
|
return $user->lang['Username_disallowed'];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Don't allow " in username.
|
|
|
|
if (strstr($username, '"'))
|
|
|
|
{
|
|
|
|
return $user->lang['Username_invalid'];
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Check to see if email address is banned or already present in the DB
|
|
|
|
function validate_email($email)
|
|
|
|
{
|
|
|
|
global $db, $user;
|
|
|
|
|
|
|
|
if ($email != '')
|
|
|
|
{
|
|
|
|
if (preg_match('/^[a-z0-9\.\-_\+]+@[a-z0-9\-_]+\.([a-z0-9\-_]+\.)*?[a-z]+$/is', $email))
|
|
|
|
{
|
|
|
|
$sql = "SELECT ban_email
|
|
|
|
FROM " . BANLIST_TABLE;
|
|
|
|
$result = $db->sql_query($sql);
|
|
|
|
|
|
|
|
while ($row = $db->sql_fetchrow($result))
|
|
|
|
{
|
|
|
|
if (preg_match('/^' . str_replace('*', '.*?', $row['ban_email']) . '$/is', $email))
|
|
|
|
{
|
|
|
|
return $user->lang['Email_banned'];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$sql = "SELECT user_email
|
|
|
|
FROM " . USERS_TABLE . "
|
|
|
|
WHERE user_email = '" . sql_quote($email) . "'";
|
|
|
|
$result = $db->sql_query($sql);
|
|
|
|
|
|
|
|
if ($row = $db->sql_fetchrow($result))
|
|
|
|
{
|
|
|
|
return $user->lang['Email_taken'];
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return $user->lang['Email_invalid'];
|
|
|
|
}
|
|
|
|
|
|
|
|
// Does supplementary validation of optional profile fields. This
|
|
|
|
// expects common stuff like trim() and strip_tags() to have already
|
|
|
|
// been run. Params are passed by-ref, so we can set them to the empty
|
|
|
|
// string if they fail.
|
|
|
|
function validate_optional_fields(&$icq, &$aim, &$msnm, &$yim, &$website, &$location, &$occupation, &$interests, &$sig)
|
|
|
|
{
|
|
|
|
$check_var_length = array('aim', 'msnm', 'yim', 'location', 'occupation', 'interests', 'sig');
|
|
|
|
|
|
|
|
for($i = 0; $i < count($check_var_length); $i++)
|
|
|
|
{
|
2002-11-18 18:56:27 +00:00
|
|
|
if (strlen($$check_var_length[$i]) < 2)
|
2002-10-30 00:57:27 +00:00
|
|
|
{
|
|
|
|
$$check_var_length[$i] = '';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// ICQ number has to be only numbers.
|
2002-11-18 18:56:27 +00:00
|
|
|
if (!preg_match('/^[0-9]+$/', $icq))
|
2002-10-30 00:57:27 +00:00
|
|
|
{
|
|
|
|
$icq = '';
|
|
|
|
}
|
|
|
|
|
|
|
|
// website has to start with http://, followed by something with length at least 3 that
|
|
|
|
// contains at least one dot.
|
2002-11-18 18:56:27 +00:00
|
|
|
if ($website != '')
|
2002-10-30 00:57:27 +00:00
|
|
|
{
|
2002-11-18 18:56:27 +00:00
|
|
|
if (!preg_match('#^http:\/\/#i', $website))
|
2002-10-30 00:57:27 +00:00
|
|
|
{
|
|
|
|
$website = 'http://' . $website;
|
|
|
|
}
|
|
|
|
|
2002-11-18 18:56:27 +00:00
|
|
|
if (!preg_match('#^http\\:\\/\\/[a-z0-9\-]+\.([a-z0-9\-]+\.)?[a-z]+#i', $website))
|
2002-10-30 00:57:27 +00:00
|
|
|
{
|
|
|
|
$website = '';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2002-07-14 14:35:12 +00:00
|
|
|
// This is general replacement for die(), allows templated output in users (or default)
|
|
|
|
// language, etc. $msg_code can be one of these constants:
|
2001-09-25 18:18:47 +00:00
|
|
|
//
|
2002-07-14 14:35:12 +00:00
|
|
|
// -> MESSAGE : Use for any simple text message, eg. results of an operation, authorisation
|
|
|
|
// failures, etc.
|
|
|
|
// -> ERROR : Use for any error, a simple page will be output
|
2002-08-06 15:32:25 +00:00
|
|
|
function message_die($msg_code, $msg_text = '', $msg_title = '')
|
2001-09-25 18:18:47 +00:00
|
|
|
{
|
2002-10-30 00:57:27 +00:00
|
|
|
global $db, $auth, $template, $config, $user, $nav_links;
|
2002-10-20 19:19:07 +00:00
|
|
|
global $phpEx, $phpbb_root_path, $starttime;
|
2001-09-25 18:18:47 +00:00
|
|
|
|
2002-11-18 18:56:27 +00:00
|
|
|
switch ($msg_code)
|
2001-09-25 18:18:47 +00:00
|
|
|
{
|
2002-07-14 14:35:12 +00:00
|
|
|
case MESSAGE:
|
2002-11-18 18:56:27 +00:00
|
|
|
$msg_title = ($msg_title == '') ? $user->lang['Information'] : $msg_title;
|
|
|
|
$msg_text = (!empty($user->lang[$msg_text])) ? $user->lang[$msg_text] : $msg_text;
|
2002-08-06 15:32:25 +00:00
|
|
|
|
2002-11-18 18:56:27 +00:00
|
|
|
if (!defined('HEADER_INC'))
|
2001-09-25 18:18:47 +00:00
|
|
|
{
|
2002-11-18 18:56:27 +00:00
|
|
|
if (empty($user->lang))
|
2002-08-05 14:59:47 +00:00
|
|
|
{
|
2002-08-06 15:32:25 +00:00
|
|
|
echo '<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"><html><meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1"><meta http-equiv="Content-Style-Type" content="text/css"><link rel="stylesheet" href="admin/subSilver.css" type="text/css"><style type="text/css">th { background-image: url(\'admin/images/cellpic3.gif\') } td.cat { background-image: url(\'admin/images/cellpic1.gif\') }</style><title>' . $msg_title . '</title></html>' . "\n";
|
|
|
|
echo '<body><table width="100%" height="100%" border="0"><tr><td align="center" valign="middle"><table class="bg" width="80%" cellspacing="1" cellpadding="4" border="0"><tr><th>' . $msg_title . '</th></tr><tr><td class="row1" align="center">' . $msg_text . '</td></tr></table></td></tr></table></body></html>';
|
|
|
|
$db->sql_close();
|
|
|
|
exit;
|
2002-08-05 14:59:47 +00:00
|
|
|
}
|
2002-11-18 18:56:27 +00:00
|
|
|
else if (defined('IN_ADMIN'))
|
2002-08-05 14:59:47 +00:00
|
|
|
{
|
2002-08-05 15:01:48 +00:00
|
|
|
page_header('', '', false);
|
2002-08-05 14:59:47 +00:00
|
|
|
}
|
2002-08-06 15:32:25 +00:00
|
|
|
else
|
|
|
|
{
|
|
|
|
include($phpbb_root_path . 'includes/page_header.' . $phpEx);
|
|
|
|
}
|
2001-09-25 18:18:47 +00:00
|
|
|
}
|
|
|
|
|
2002-11-18 18:56:27 +00:00
|
|
|
if (defined('IN_ADMIN'))
|
2001-09-25 18:18:47 +00:00
|
|
|
{
|
2002-07-17 14:13:27 +00:00
|
|
|
page_message($msg_title, $msg_text, $display_header);
|
2002-08-06 15:32:25 +00:00
|
|
|
page_footer();
|
2001-09-25 18:18:47 +00:00
|
|
|
}
|
2002-07-14 14:35:12 +00:00
|
|
|
else
|
2001-09-25 18:18:47 +00:00
|
|
|
{
|
2002-07-14 14:35:12 +00:00
|
|
|
$template->set_filenames(array(
|
|
|
|
'body' => 'message_body.html')
|
|
|
|
);
|
|
|
|
|
|
|
|
$template->assign_vars(array(
|
|
|
|
'MESSAGE_TITLE' => $msg_title,
|
|
|
|
'MESSAGE_TEXT' => $msg_text)
|
|
|
|
);
|
2001-09-25 18:18:47 +00:00
|
|
|
|
2002-08-06 00:50:06 +00:00
|
|
|
include($phpbb_root_path . 'includes/page_tail.' . $phpEx);
|
2002-08-05 14:59:47 +00:00
|
|
|
}
|
2002-08-06 15:32:25 +00:00
|
|
|
|
2001-09-25 18:18:47 +00:00
|
|
|
break;
|
2001-10-14 15:48:38 +00:00
|
|
|
|
2002-07-14 14:35:12 +00:00
|
|
|
case ERROR:
|
2002-10-10 00:35:35 +00:00
|
|
|
$db->sql_close();
|
|
|
|
|
2002-10-26 12:34:39 +00:00
|
|
|
echo '<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"><html><head><meta http-equiv="Content-Type" content="text/html; charset=iso-8869-1"><meta http-equiv="Content-Style-Type" content="text/css"><link rel="stylesheet" href="../admin/subSilver.css" type="text/css"><style type="text/css">';
|
|
|
|
echo 'th { background-image: url(\'../admin/images/cellpic3.gif\') }';
|
|
|
|
echo 'td.cat { background-image: url(\'../admin/images/cellpic1.gif\') }';
|
|
|
|
echo '</style><title>' . $msg_title . '</title></head><body><table width="100%" cellspacing="0" cellpadding="0" border="0"><tr><td colspan="2" height="25" align="right" nowrap="nowrap"><span class="subtitle">» <i>' . $msg_title . '</i></span> </td></tr></table><table width="95%" cellspacing="0" cellpadding="0" border="0" align="center"><tr><td><br clear="all" />' . $msg_text . '</td></tr></table><br clear="all" /></body></html>';
|
2002-07-14 14:35:12 +00:00
|
|
|
break;
|
2001-09-25 18:18:47 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
2002-10-08 20:06:55 +00:00
|
|
|
// Error and message handler, call with trigger_error if reqd
|
|
|
|
function msg_handler($errno, $msg_text, $errfile, $errline)
|
|
|
|
{
|
2002-10-30 00:57:27 +00:00
|
|
|
global $db, $auth, $template, $config, $user, $nav_links;
|
2002-10-20 19:19:07 +00:00
|
|
|
global $phpEx, $phpbb_root_path, $starttime;
|
2002-10-08 20:06:55 +00:00
|
|
|
|
2002-11-01 12:23:08 +00:00
|
|
|
switch ($errno)
|
2002-10-08 20:06:55 +00:00
|
|
|
{
|
|
|
|
case E_WARNING:
|
2002-10-26 12:34:39 +00:00
|
|
|
// if (defined('DEBUG'))
|
|
|
|
// {
|
|
|
|
// echo "PHP Warning on line <b>$errline</b> in <b>$errfile</b> :: <b>$msg_text</b>";
|
|
|
|
// }
|
2002-10-08 20:06:55 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case E_NOTICE:
|
2002-10-26 12:34:39 +00:00
|
|
|
// if (defined('DEBUG_EXTRA'))
|
|
|
|
// {
|
|
|
|
// echo "PHP Notice on line <b>$errline</b> in <b>$errfile</b> :: <b>$msg_text</b>";
|
|
|
|
// }
|
2002-10-08 20:06:55 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case E_USER_ERROR:
|
2002-11-01 12:23:08 +00:00
|
|
|
if (isset($db))
|
2002-10-20 19:19:07 +00:00
|
|
|
{
|
|
|
|
$db->sql_close();
|
|
|
|
}
|
2002-10-10 00:35:35 +00:00
|
|
|
|
2002-10-26 12:34:39 +00:00
|
|
|
echo '<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"><html><head><meta http-equiv="Content-Type" content="text/html; charset=iso-8869-1"><meta http-equiv="Content-Style-Type" content="text/css"><link rel="stylesheet" href="' . $phpbb_root_path . 'admin/subSilver.css" type="text/css"><style type="text/css">' . "\n";
|
|
|
|
echo 'th { background-image: url(\'' . $phpbb_root_path . 'admin/images/cellpic3.gif\') }' . "\n";
|
|
|
|
echo 'td.cat { background-image: url(\'' . $phpbb_root_path . 'admin/images/cellpic1.gif\') }' . "\n";
|
|
|
|
echo '</style><title>' . $msg_title . '</title></head><body>';
|
2002-10-30 00:57:27 +00:00
|
|
|
echo '<table width="100%" cellspacing="0" cellpadding="0" border="0"><tr><td><img src="' . $phpbb_root_path . 'admin/images/header_left.jpg" width="200" height="60" alt="phpBB Logo" title="phpBB Logo" border="0"/></td><td width="100%" background="' . $phpbb_root_path . 'admin/images/header_bg.jpg" height="60" align="right" nowrap="nowrap"><span class="maintitle">General Error</span> </td></tr></table><br clear="all" /><table width="85%" cellspacing="0" cellpadding="0" border="0" align="center"><tr><td><br clear="all" />' . $msg_text . '<hr />Please notify the board administrator or webmaster : <a href="mailto:' . $config['board_email'] . '">' . $config['board_email'] . '</a></td></tr></table><br clear="all" /></body></html>';
|
2002-10-26 12:34:39 +00:00
|
|
|
|
2002-10-20 19:19:07 +00:00
|
|
|
exit;
|
2002-10-08 20:06:55 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case E_USER_NOTICE:
|
2002-11-01 12:23:08 +00:00
|
|
|
if (empty($user->session_id))
|
|
|
|
{
|
|
|
|
$user->start();
|
|
|
|
}
|
|
|
|
if (empty($user->lang))
|
|
|
|
{
|
|
|
|
$user->setup();
|
|
|
|
}
|
2002-10-08 20:06:55 +00:00
|
|
|
|
2002-11-01 12:23:08 +00:00
|
|
|
$msg_text = (!empty($user->lang[$msg_text])) ? $user->lang[$msg_text] : $msg_text;
|
|
|
|
|
|
|
|
if (!defined('HEADER_INC'))
|
2002-10-08 20:06:55 +00:00
|
|
|
{
|
2002-11-01 12:23:08 +00:00
|
|
|
if (defined('IN_ADMIN'))
|
2002-10-08 20:06:55 +00:00
|
|
|
{
|
|
|
|
page_header('', '', false);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
include($phpbb_root_path . 'includes/page_header.' . $phpEx);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2002-11-01 12:23:08 +00:00
|
|
|
if (defined('IN_ADMIN'))
|
2002-10-08 20:06:55 +00:00
|
|
|
{
|
|
|
|
page_message($msg_title, $msg_text, $display_header);
|
|
|
|
page_footer();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
$template->set_filenames(array(
|
|
|
|
'body' => 'message_body.html')
|
|
|
|
);
|
|
|
|
|
|
|
|
$template->assign_vars(array(
|
2002-11-01 12:23:08 +00:00
|
|
|
'MESSAGE_TITLE' => $msg_title,
|
|
|
|
'MESSAGE_TEXT' => $msg_text)
|
2002-10-08 20:06:55 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
include($phpbb_root_path . 'includes/page_tail.' . $phpEx);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2002-03-18 13:35:23 +00:00
|
|
|
?>
|