mirror of
https://github.com/phpbb/phpbb.git
synced 2025-06-10 13:28:55 +00:00
- a handful of mcp fixed, the most important one is the change for check_ids() - it is now supporting ids from more than one forum too, making it possible to use some mcp features as designed initially. We really need to get our moderator team testing the mcp extensively.
- fixed some other tiny glitches - if a forum category with subforums get changed to a link type forum give options of what to do with the subforums (#5334) - other bugfixes git-svn-id: file:///svn/phpbb/trunk@6601 89ea8834-ac86-4346-8a33-228a782c2dd0
This commit is contained in:
parent
5f788b4d08
commit
e264a62b73
30 changed files with 466 additions and 242 deletions
|
@ -23,6 +23,17 @@
|
||||||
}
|
}
|
||||||
<!-- ENDIF -->
|
<!-- ENDIF -->
|
||||||
|
|
||||||
|
<!-- IF not S_ADD_ACTION and S_FORUM_ORIG_CAT and S_HAS_SUBFORUMS -->
|
||||||
|
if (value == {FORUM_LINK})
|
||||||
|
{
|
||||||
|
dE('cat_to_link_actions', 1);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
dE('cat_to_link_actions', -1);
|
||||||
|
}
|
||||||
|
<!-- ENDIF -->
|
||||||
|
|
||||||
if (value == {FORUM_POST})
|
if (value == {FORUM_POST})
|
||||||
{
|
{
|
||||||
dE('forum_post_options', 1);
|
dE('forum_post_options', 1);
|
||||||
|
@ -58,6 +69,12 @@
|
||||||
<!-- ENDIF -->
|
<!-- ENDIF -->
|
||||||
<!-- ENDIF -->
|
<!-- ENDIF -->
|
||||||
|
|
||||||
|
<!-- IF not S_ADD_ACTION and S_FORUM_ORIG_CAT and S_HAS_SUBFORUMS -->
|
||||||
|
<!-- IF S_FORUM_CAT -->
|
||||||
|
dE('cat_to_link_actions', -1);
|
||||||
|
<!-- ENDIF -->
|
||||||
|
<!-- ENDIF -->
|
||||||
|
|
||||||
<!-- IF not S_FORUM_POST -->
|
<!-- IF not S_FORUM_POST -->
|
||||||
dE('forum_post_options', -1);
|
dE('forum_post_options', -1);
|
||||||
<!-- ENDIF -->
|
<!-- ENDIF -->
|
||||||
|
@ -108,6 +125,18 @@
|
||||||
</dl>
|
</dl>
|
||||||
</div>
|
</div>
|
||||||
<!-- ENDIF -->
|
<!-- ENDIF -->
|
||||||
|
<!-- IF not S_ADD_ACTION and S_FORUM_ORIG_CAT and S_HAS_SUBFORUMS -->
|
||||||
|
<div id="cat_to_link_actions">
|
||||||
|
<dl>
|
||||||
|
<dt><label for="action_subforums">{L_DECIDE_MOVE_DELETE_SUBFORUMS}:</label></dt>
|
||||||
|
<!-- IF S_FORUMS_LIST -->
|
||||||
|
<dd><input type="radio" class="radio" name="action_subforums" value="move" checked="checked" /> {L_MOVE_SUBFORUMS_TO} <select name="subforums_to_id">{S_FORUMS_LIST}</select></dd>
|
||||||
|
<!-- ELSE -->
|
||||||
|
<dd><input type="radio" class="radio" id="action_subforums" name="action_subforums" value="delete" checked="checked" /> {L_DELETE_SUBFORUMS}</dd>
|
||||||
|
<!-- ENDIF -->
|
||||||
|
</dl>
|
||||||
|
</div>
|
||||||
|
<!-- ENDIF -->
|
||||||
<dl>
|
<dl>
|
||||||
<dt><label for="parent">{L_FORUM_PARENT}:</label></dt>
|
<dt><label for="parent">{L_FORUM_PARENT}:</label></dt>
|
||||||
<dd><select id="parent" name="forum_parent_id"><option value="0"<!-- IF not S_FORUM_PARENT_ID --> selected="selected"<!-- ENDIF -->>{L_NO_PARENT}</option>{S_PARENT_OPTIONS}</select></dd>
|
<dd><select id="parent" name="forum_parent_id"><option value="0"<!-- IF not S_FORUM_PARENT_ID --> selected="selected"<!-- ENDIF -->>{L_NO_PARENT}</option>{S_PARENT_OPTIONS}</select></dd>
|
||||||
|
|
|
@ -61,23 +61,6 @@
|
||||||
|
|
||||||
</form>
|
</form>
|
||||||
|
|
||||||
<form id="select_single_forum" method="post" action="{U_ACTION}">
|
|
||||||
|
|
||||||
<fieldset>
|
|
||||||
<legend>{L_LOOK_UP_FORUM}</legend>
|
|
||||||
<dl>
|
|
||||||
<dt><label for="forum">{L_LOOK_UP_FORUM}:</label></dt>
|
|
||||||
<dd><select id="forum" name="forum_id[]">{S_FORUM_OPTIONS}</select></dd>
|
|
||||||
</dl>
|
|
||||||
</fieldset>
|
|
||||||
|
|
||||||
<fieldset class="quick">
|
|
||||||
{S_HIDDEN_FIELDS}
|
|
||||||
<input type="submit" name="submit" value="{L_SUBMIT}" class="button1" />
|
|
||||||
</fieldset>
|
|
||||||
|
|
||||||
</form>
|
|
||||||
|
|
||||||
<!-- ENDIF -->
|
<!-- ENDIF -->
|
||||||
|
|
||||||
<!-- ELSEIF S_SELECT_USER and S_CAN_SELECT_USER -->
|
<!-- ELSEIF S_SELECT_USER and S_CAN_SELECT_USER -->
|
||||||
|
|
|
@ -524,6 +524,39 @@ class acp_forums
|
||||||
}
|
}
|
||||||
$db->sql_freeresult($result);
|
$db->sql_freeresult($result);
|
||||||
|
|
||||||
|
// Subforum move options
|
||||||
|
if ($action == 'edit' && $forum_data['forum_type'] == FORUM_CAT)
|
||||||
|
{
|
||||||
|
$subforums_id = array();
|
||||||
|
$subforums = get_forum_branch($forum_id, 'children');
|
||||||
|
|
||||||
|
foreach ($subforums as $row)
|
||||||
|
{
|
||||||
|
$subforums_id[] = $row['forum_id'];
|
||||||
|
}
|
||||||
|
|
||||||
|
$forums_list = make_forum_select($forum_data['parent_id'], $subforums_id);
|
||||||
|
|
||||||
|
$sql = 'SELECT forum_id
|
||||||
|
FROM ' . FORUMS_TABLE . '
|
||||||
|
WHERE forum_type = ' . FORUM_POST . "
|
||||||
|
AND forum_id <> $forum_id";
|
||||||
|
$result = $db->sql_query($sql);
|
||||||
|
|
||||||
|
if ($db->sql_fetchrow($result))
|
||||||
|
{
|
||||||
|
$template->assign_vars(array(
|
||||||
|
'S_MOVE_FORUM_OPTIONS' => make_forum_select($forum_data['parent_id'], $subforums_id)) // , false, true, false???
|
||||||
|
);
|
||||||
|
}
|
||||||
|
$db->sql_freeresult($result);
|
||||||
|
|
||||||
|
$template->assign_vars(array(
|
||||||
|
'S_HAS_SUBFORUMS' => ($forum_data['right_id'] - $forum_data['left_id'] > 1) ? true : false,
|
||||||
|
'S_FORUMS_LIST' => $forums_list)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
$s_show_display_on_index = false;
|
$s_show_display_on_index = false;
|
||||||
|
|
||||||
if ($forum_data['parent_id'] > 0)
|
if ($forum_data['parent_id'] > 0)
|
||||||
|
@ -586,6 +619,8 @@ class acp_forums
|
||||||
'S_SHOW_DISPLAY_ON_INDEX' => $s_show_display_on_index,
|
'S_SHOW_DISPLAY_ON_INDEX' => $s_show_display_on_index,
|
||||||
'S_FORUM_POST' => ($forum_data['forum_type'] == FORUM_POST) ? true : false,
|
'S_FORUM_POST' => ($forum_data['forum_type'] == FORUM_POST) ? true : false,
|
||||||
'S_FORUM_ORIG_POST' => (isset($old_forum_type) && $old_forum_type == FORUM_POST) ? true : false,
|
'S_FORUM_ORIG_POST' => (isset($old_forum_type) && $old_forum_type == FORUM_POST) ? true : false,
|
||||||
|
'S_FORUM_ORIG_CAT' => (isset($old_forum_type) && $old_forum_type == FORUM_CAT) ? true : false,
|
||||||
|
'S_FORUM_ORIG_LINK' => (isset($old_forum_type) && $old_forum_type == FORUM_LINK) ? true : false,
|
||||||
'S_FORUM_LINK' => ($forum_data['forum_type'] == FORUM_LINK) ? true : false,
|
'S_FORUM_LINK' => ($forum_data['forum_type'] == FORUM_LINK) ? true : false,
|
||||||
'S_FORUM_CAT' => ($forum_data['forum_type'] == FORUM_CAT) ? true : false,
|
'S_FORUM_CAT' => ($forum_data['forum_type'] == FORUM_CAT) ? true : false,
|
||||||
'S_ENABLE_INDEXING' => ($forum_data['enable_indexing']) ? true : false,
|
'S_ENABLE_INDEXING' => ($forum_data['enable_indexing']) ? true : false,
|
||||||
|
@ -802,7 +837,7 @@ class acp_forums
|
||||||
*/
|
*/
|
||||||
function update_forum_data(&$forum_data)
|
function update_forum_data(&$forum_data)
|
||||||
{
|
{
|
||||||
global $db, $user;
|
global $db, $user, $cache;
|
||||||
|
|
||||||
$errors = array();
|
$errors = array();
|
||||||
|
|
||||||
|
@ -943,6 +978,123 @@ class acp_forums
|
||||||
$forum_data_sql['forum_posts'] = $forum_data_sql['forum_topics'] = $forum_data_sql['forum_topics_real'] = $forum_data_sql['forum_last_post_id'] = $forum_data_sql['forum_last_poster_id'] = $forum_data_sql['forum_last_post_time'] = 0;
|
$forum_data_sql['forum_posts'] = $forum_data_sql['forum_topics'] = $forum_data_sql['forum_topics_real'] = $forum_data_sql['forum_last_post_id'] = $forum_data_sql['forum_last_poster_id'] = $forum_data_sql['forum_last_post_time'] = 0;
|
||||||
$forum_data_sql['forum_last_poster_name'] = $forum_data_sql['forum_last_poster_colour'] = '';
|
$forum_data_sql['forum_last_poster_name'] = $forum_data_sql['forum_last_poster_colour'] = '';
|
||||||
}
|
}
|
||||||
|
else if ($row['forum_type'] == FORUM_CAT && $forum_data_sql['forum_type'] == FORUM_LINK)
|
||||||
|
{
|
||||||
|
// Has subforums?
|
||||||
|
if ($row['right_id'] - $row['left_id'] > 1)
|
||||||
|
{
|
||||||
|
// We are turning a category into a link - but need to decide what to do with the subforums.
|
||||||
|
$action_subforums = request_var('action_subforums', '');
|
||||||
|
$subforums_to_id = request_var('subforums_to_id', 0);
|
||||||
|
|
||||||
|
if ($action_subforums == 'delete')
|
||||||
|
{
|
||||||
|
$log_action_forums = 'FORUMS';
|
||||||
|
$rows = get_forum_branch($row['forum_id'], 'children', 'descending', false);
|
||||||
|
|
||||||
|
foreach ($rows as $_row)
|
||||||
|
{
|
||||||
|
// Do not remove the forum id we are about to change. ;)
|
||||||
|
if ($_row['forum_id'] == $row['forum_id'])
|
||||||
|
{
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
$forum_ids[] = $_row['forum_id'];
|
||||||
|
$errors = array_merge($errors, $this->delete_forum_content($_row['forum_id']));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (sizeof($errors))
|
||||||
|
{
|
||||||
|
return $errors;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (sizeof($forum_ids))
|
||||||
|
{
|
||||||
|
$sql = 'DELETE FROM ' . FORUMS_TABLE . '
|
||||||
|
WHERE ' . $db->sql_in_set('forum_id', $forum_ids);
|
||||||
|
$db->sql_query($sql);
|
||||||
|
|
||||||
|
$sql = 'DELETE FROM ' . ACL_GROUPS_TABLE . '
|
||||||
|
WHERE ' . $db->sql_in_set('forum_id', $forum_ids);
|
||||||
|
$db->sql_query($sql);
|
||||||
|
|
||||||
|
$sql = 'DELETE FROM ' . ACL_USERS_TABLE . '
|
||||||
|
WHERE ' . $db->sql_in_set('forum_id', $forum_ids);
|
||||||
|
$db->sql_query($sql);
|
||||||
|
|
||||||
|
// Delete forum ids from extension groups table
|
||||||
|
$sql = 'SELECT group_id, allowed_forums
|
||||||
|
FROM ' . EXTENSION_GROUPS_TABLE;
|
||||||
|
$result = $db->sql_query($sql);
|
||||||
|
|
||||||
|
while ($_row = $db->sql_fetchrow($result))
|
||||||
|
{
|
||||||
|
if (!$_row['allowed_forums'])
|
||||||
|
{
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
$allowed_forums = unserialize(trim($_row['allowed_forums']));
|
||||||
|
$allowed_forums = array_diff($allowed_forums, $forum_ids);
|
||||||
|
|
||||||
|
$sql = 'UPDATE ' . EXTENSION_GROUPS_TABLE . "
|
||||||
|
SET allowed_forums = '" . ((sizeof($allowed_forums)) ? serialize($allowed_forums) : '') . "'
|
||||||
|
WHERE group_id = {$_row['group_id']}";
|
||||||
|
$db->sql_query($sql);
|
||||||
|
}
|
||||||
|
$db->sql_freeresult($result);
|
||||||
|
|
||||||
|
$cache->destroy('_extensions');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if ($action_subforums == 'move')
|
||||||
|
{
|
||||||
|
if (!$subforums_to_id)
|
||||||
|
{
|
||||||
|
return array($user->lang['NO_DESTINATION_FORUM']);
|
||||||
|
}
|
||||||
|
|
||||||
|
$log_action_forums = 'MOVE_FORUMS';
|
||||||
|
|
||||||
|
$sql = 'SELECT forum_name
|
||||||
|
FROM ' . FORUMS_TABLE . '
|
||||||
|
WHERE forum_id = ' . $subforums_to_id;
|
||||||
|
$result = $db->sql_query($sql);
|
||||||
|
$_row = $db->sql_fetchrow($result);
|
||||||
|
$db->sql_freeresult($result);
|
||||||
|
|
||||||
|
if (!$_row)
|
||||||
|
{
|
||||||
|
return array($user->lang['NO_FORUM']);
|
||||||
|
}
|
||||||
|
|
||||||
|
$subforums_to_name = $_row['forum_name'];
|
||||||
|
|
||||||
|
$sql = 'SELECT forum_id
|
||||||
|
FROM ' . FORUMS_TABLE . "
|
||||||
|
WHERE parent_id = {$row['forum_id']}";
|
||||||
|
$result = $db->sql_query($sql);
|
||||||
|
|
||||||
|
while ($_row = $db->sql_fetchrow($result))
|
||||||
|
{
|
||||||
|
$this->move_forum($_row['forum_id'], $subforums_to_id);
|
||||||
|
}
|
||||||
|
$db->sql_freeresult($result);
|
||||||
|
|
||||||
|
$sql = 'UPDATE ' . FORUMS_TABLE . "
|
||||||
|
SET parent_id = $subforums_to_id
|
||||||
|
WHERE parent_id = {$row['forum_id']}";
|
||||||
|
$db->sql_query($sql);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Adjust the left/right id
|
||||||
|
$sql = 'UPDATE ' . FORUMS_TABLE . '
|
||||||
|
SET right_id = left_id + 1
|
||||||
|
WHERE forum_id = ' . $row['forum_id'];
|
||||||
|
$db->sql_query($sql);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (sizeof($errors))
|
if (sizeof($errors))
|
||||||
{
|
{
|
||||||
|
@ -1534,8 +1686,6 @@ class acp_forums
|
||||||
|
|
||||||
set_config('upload_dir_size', (int) $row['stat'], true);
|
set_config('upload_dir_size', (int) $row['stat'], true);
|
||||||
|
|
||||||
add_log('admin', 'LOG_RESYNC_STATS');
|
|
||||||
|
|
||||||
return array();
|
return array();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -214,9 +214,10 @@ class acp_groups
|
||||||
}
|
}
|
||||||
|
|
||||||
$name_ary = array_unique(explode("\n", $name_ary));
|
$name_ary = array_unique(explode("\n", $name_ary));
|
||||||
|
$group_name = ($group_row['group_type'] == GROUP_SPECIAL) ? $user->lang['G_' . $group_row['group_name']] : $group_row['group_name'];
|
||||||
|
|
||||||
// Add user/s to group
|
// Add user/s to group
|
||||||
if ($error = group_user_add($group_id, false, $name_ary, $group_row['group_name'], $default, $leader, 0, $group_row))
|
if ($error = group_user_add($group_id, false, $name_ary, $group_name, $default, $leader, 0, $group_row))
|
||||||
{
|
{
|
||||||
trigger_error($user->lang[$error] . adm_back_link($this->u_action . '&action=list&g=' . $group_id), E_USER_WARNING);
|
trigger_error($user->lang[$error] . adm_back_link($this->u_action . '&action=list&g=' . $group_id), E_USER_WARNING);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1921,7 +1921,7 @@ class acp_users
|
||||||
|
|
||||||
if ($db->sql_layer == 'mssql' || $db->sql_layer == 'mssql_odbc')
|
if ($db->sql_layer == 'mssql' || $db->sql_layer == 'mssql_odbc')
|
||||||
{
|
{
|
||||||
$sql .= " ESCAPE '\\'";
|
$sql .= " ESCAPE '\\' ";
|
||||||
}
|
}
|
||||||
|
|
||||||
$sql .= 'AND is_global = 1
|
$sql .= 'AND is_global = 1
|
||||||
|
@ -1941,7 +1941,7 @@ class acp_users
|
||||||
|
|
||||||
if ($db->sql_layer == 'mssql' || $db->sql_layer == 'mssql_odbc')
|
if ($db->sql_layer == 'mssql' || $db->sql_layer == 'mssql_odbc')
|
||||||
{
|
{
|
||||||
$sql .= " ESCAPE '\\'";
|
$sql .= " ESCAPE '\\' ";
|
||||||
}
|
}
|
||||||
|
|
||||||
$sql .= 'AND is_local = 1
|
$sql .= 'AND is_local = 1
|
||||||
|
|
|
@ -478,11 +478,11 @@ class auth
|
||||||
$sql_user = ($user_id !== false) ? ((!is_array($user_id)) ? "user_id = $user_id" : $db->sql_in_set('user_id', $user_id)) : '';
|
$sql_user = ($user_id !== false) ? ((!is_array($user_id)) ? "user_id = $user_id" : $db->sql_in_set('user_id', $user_id)) : '';
|
||||||
$sql_forum = ($forum_id !== false) ? ((!is_array($forum_id)) ? "AND a.forum_id = $forum_id" : 'AND ' . $db->sql_in_set('a.forum_id', $forum_id)) : '';
|
$sql_forum = ($forum_id !== false) ? ((!is_array($forum_id)) ? "AND a.forum_id = $forum_id" : 'AND ' . $db->sql_in_set('a.forum_id', $forum_id)) : '';
|
||||||
|
|
||||||
$sql_opts = $sql_escape = '';
|
$sql_opts = '';
|
||||||
|
|
||||||
if ($opts !== false)
|
if ($opts !== false)
|
||||||
{
|
{
|
||||||
$this->build_auth_option_statement('ao.auth_option', $opts, $sql_opts, $sql_escape);
|
$this->build_auth_option_statement('ao.auth_option', $opts, $sql_opts);
|
||||||
}
|
}
|
||||||
|
|
||||||
$hold_ary = array();
|
$hold_ary = array();
|
||||||
|
@ -512,7 +512,7 @@ class auth
|
||||||
|
|
||||||
'ORDER_BY' => 'a.forum_id, ao.auth_option'
|
'ORDER_BY' => 'a.forum_id, ao.auth_option'
|
||||||
));
|
));
|
||||||
$result = $db->sql_query($sql . $sql_escape);
|
$result = $db->sql_query($sql);
|
||||||
|
|
||||||
while ($row = $db->sql_fetchrow($result))
|
while ($row = $db->sql_fetchrow($result))
|
||||||
{
|
{
|
||||||
|
@ -588,11 +588,11 @@ class auth
|
||||||
$sql_user = ($user_id !== false) ? ((!is_array($user_id)) ? "user_id = $user_id" : $db->sql_in_set('user_id', $user_id)) : '';
|
$sql_user = ($user_id !== false) ? ((!is_array($user_id)) ? "user_id = $user_id" : $db->sql_in_set('user_id', $user_id)) : '';
|
||||||
$sql_forum = ($forum_id !== false) ? ((!is_array($forum_id)) ? "AND a.forum_id = $forum_id" : 'AND ' . $db->sql_in_set('a.forum_id', $forum_id)) : '';
|
$sql_forum = ($forum_id !== false) ? ((!is_array($forum_id)) ? "AND a.forum_id = $forum_id" : 'AND ' . $db->sql_in_set('a.forum_id', $forum_id)) : '';
|
||||||
|
|
||||||
$sql_opts = $sql_escape = '';
|
$sql_opts = '';
|
||||||
|
|
||||||
if ($opts !== false)
|
if ($opts !== false)
|
||||||
{
|
{
|
||||||
$this->build_auth_option_statement('ao.auth_option', $opts, $sql_opts, $sql_escape);
|
$this->build_auth_option_statement('ao.auth_option', $opts, $sql_opts);
|
||||||
}
|
}
|
||||||
|
|
||||||
$hold_ary = array();
|
$hold_ary = array();
|
||||||
|
@ -620,7 +620,7 @@ class auth
|
||||||
|
|
||||||
'ORDER_BY' => 'a.forum_id, ao.auth_option'
|
'ORDER_BY' => 'a.forum_id, ao.auth_option'
|
||||||
));
|
));
|
||||||
$result = $db->sql_query($sql . $sql_escape);
|
$result = $db->sql_query($sql);
|
||||||
|
|
||||||
while ($row = $db->sql_fetchrow($result))
|
while ($row = $db->sql_fetchrow($result))
|
||||||
{
|
{
|
||||||
|
@ -642,11 +642,11 @@ class auth
|
||||||
$sql_group = ($group_id !== false) ? ((!is_array($group_id)) ? "group_id = $group_id" : $db->sql_in_set('group_id', $group_id)) : '';
|
$sql_group = ($group_id !== false) ? ((!is_array($group_id)) ? "group_id = $group_id" : $db->sql_in_set('group_id', $group_id)) : '';
|
||||||
$sql_forum = ($forum_id !== false) ? ((!is_array($forum_id)) ? "AND a.forum_id = $forum_id" : 'AND ' . $db->sql_in_set('a.forum_id', $forum_id)) : '';
|
$sql_forum = ($forum_id !== false) ? ((!is_array($forum_id)) ? "AND a.forum_id = $forum_id" : 'AND ' . $db->sql_in_set('a.forum_id', $forum_id)) : '';
|
||||||
|
|
||||||
$sql_opts = $sql_escape = '';
|
$sql_opts = '';
|
||||||
|
|
||||||
if ($opts !== false)
|
if ($opts !== false)
|
||||||
{
|
{
|
||||||
$this->build_auth_option_statement('ao.auth_option', $opts, $sql_opts, $sql_escape);
|
$this->build_auth_option_statement('ao.auth_option', $opts, $sql_opts);
|
||||||
}
|
}
|
||||||
|
|
||||||
$hold_ary = array();
|
$hold_ary = array();
|
||||||
|
@ -674,7 +674,7 @@ class auth
|
||||||
|
|
||||||
'ORDER_BY' => 'a.forum_id, ao.auth_option'
|
'ORDER_BY' => 'a.forum_id, ao.auth_option'
|
||||||
));
|
));
|
||||||
$result = $db->sql_query($sql . $sql_escape);
|
$result = $db->sql_query($sql);
|
||||||
|
|
||||||
while ($row = $db->sql_fetchrow($result))
|
while ($row = $db->sql_fetchrow($result))
|
||||||
{
|
{
|
||||||
|
@ -791,7 +791,7 @@ class auth
|
||||||
/**
|
/**
|
||||||
* Fill auth_option statement for later querying based on the supplied options
|
* Fill auth_option statement for later querying based on the supplied options
|
||||||
*/
|
*/
|
||||||
function build_auth_option_statement($key, $auth_options, &$sql_opts, &$sql_escape)
|
function build_auth_option_statement($key, $auth_options, &$sql_opts)
|
||||||
{
|
{
|
||||||
global $db;
|
global $db;
|
||||||
|
|
||||||
|
@ -802,7 +802,7 @@ class auth
|
||||||
if (strpos($auth_options, '_') !== false)
|
if (strpos($auth_options, '_') !== false)
|
||||||
{
|
{
|
||||||
$sql_opts = "AND $key LIKE '" . $db->sql_escape(str_replace('_', "\_", $auth_options)) . "'";
|
$sql_opts = "AND $key LIKE '" . $db->sql_escape(str_replace('_', "\_", $auth_options)) . "'";
|
||||||
$sql_escape = ($db->sql_layer == 'mssql' || $db->sql_layer == 'mssql_odbc') ? " ESCAPE '\\'" : '';
|
$sql_opts .= ($db->sql_layer == 'mssql' || $db->sql_layer == 'mssql_odbc') ? " ESCAPE '\\' " : '';
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -816,7 +816,7 @@ class auth
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
$is_like_expression = $is_underline = false;
|
$is_like_expression = false;
|
||||||
|
|
||||||
foreach ($auth_options as $option)
|
foreach ($auth_options as $option)
|
||||||
{
|
{
|
||||||
|
@ -824,11 +824,6 @@ class auth
|
||||||
{
|
{
|
||||||
$is_like_expression = true;
|
$is_like_expression = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (strpos($option, '_') !== false)
|
|
||||||
{
|
|
||||||
$is_underline = true;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!$is_like_expression)
|
if (!$is_like_expression)
|
||||||
|
@ -841,15 +836,26 @@ class auth
|
||||||
|
|
||||||
foreach ($auth_options as $option)
|
foreach ($auth_options as $option)
|
||||||
{
|
{
|
||||||
$sql[] = $key . " LIKE '" . $db->sql_escape(str_replace('_', "\_", $option)) . "'";
|
if (strpos($option, '%') !== false)
|
||||||
|
{
|
||||||
|
if (strpos($option, '_') !== false)
|
||||||
|
{
|
||||||
|
$_sql = $key . " LIKE '" . $db->sql_escape(str_replace('_', "\_", $option)) . "'";
|
||||||
|
$_sql .= ($db->sql_layer == 'mssql' || $db->sql_layer == 'mssql_odbc') ? " ESCAPE '\\'" : '';
|
||||||
|
$sql[] = $_sql;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$sql[] = $key . " LIKE '" . $db->sql_escape($option) . "'";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$sql[] = $key . " = '" . $db->sql_escape($option) . "'";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$sql_opts = 'AND (' . implode(' OR ', $sql) . ')';
|
$sql_opts = 'AND (' . implode(' OR ', $sql) . ')';
|
||||||
|
|
||||||
if ($is_underline)
|
|
||||||
{
|
|
||||||
$sql_escape = ($db->sql_layer == 'mssql' || $db->sql_layer == 'mssql_odbc') ? " ESCAPE '\\'" : '';
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -2512,7 +2512,7 @@ function _build_hidden_fields($key, $value, $specialchar, $stripslashes)
|
||||||
{
|
{
|
||||||
foreach ($value as $_key => $_value)
|
foreach ($value as $_key => $_value)
|
||||||
{
|
{
|
||||||
$_key = ($stripslashes) ? stripslashes($_key) : $key;
|
$_key = ($stripslashes) ? stripslashes($_key) : $_key;
|
||||||
$_key = ($specialchar) ? htmlspecialchars($_key, ENT_COMPAT, 'UTF-8') : $_key;
|
$_key = ($specialchar) ? htmlspecialchars($_key, ENT_COMPAT, 'UTF-8') : $_key;
|
||||||
|
|
||||||
$hidden_fields .= _build_hidden_fields($key . '[' . $_key . ']', $_value, $specialchar, $stripslashes);
|
$hidden_fields .= _build_hidden_fields($key . '[' . $_key . ']', $_value, $specialchar, $stripslashes);
|
||||||
|
@ -3085,7 +3085,7 @@ function page_header($page_title = '', $display_online_list = true)
|
||||||
// Specify escape character for MSSQL
|
// Specify escape character for MSSQL
|
||||||
if ($db->sql_layer == 'mssql' || $db->sql_layer == 'mssql_odbc')
|
if ($db->sql_layer == 'mssql' || $db->sql_layer == 'mssql_odbc')
|
||||||
{
|
{
|
||||||
$reading_sql .= " ESCAPE '\\'";
|
$reading_sql .= " ESCAPE '\\' ";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -367,7 +367,7 @@ function upload_attachment($form_name, $forum_id, $local = false, $local_storage
|
||||||
// Check Image Size, if it is an image
|
// Check Image Size, if it is an image
|
||||||
if (!$auth->acl_get('a_') && !$auth->acl_get('m_', $forum_id) && $cat_id == ATTACHMENT_CATEGORY_IMAGE)
|
if (!$auth->acl_get('a_') && !$auth->acl_get('m_', $forum_id) && $cat_id == ATTACHMENT_CATEGORY_IMAGE)
|
||||||
{
|
{
|
||||||
$file->upload->set_allowed_dimensions(0, 0, $config['img_max_width'], $config['img_max_height']);
|
$file->upload->set_allowed_dimensions(0, 0, $config['img_max_width'], $config['img_max_height']);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Admins and mods are allowed to exceed the allowed filesize
|
// Admins and mods are allowed to exceed the allowed filesize
|
||||||
|
@ -561,6 +561,12 @@ function create_thumbnail($source, $destination, $mimetype)
|
||||||
|
|
||||||
list($new_width, $new_height) = get_img_size_format($width, $height);
|
list($new_width, $new_height) = get_img_size_format($width, $height);
|
||||||
|
|
||||||
|
// Do not create a thumbnail if the resulting width/height is bigger than the original one
|
||||||
|
if ($new_width > $width && $new_height > $height)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
$used_imagick = false;
|
$used_imagick = false;
|
||||||
|
|
||||||
// Only use imagemagick if defined and the passthru function not disabled
|
// Only use imagemagick if defined and the passthru function not disabled
|
||||||
|
|
|
@ -79,7 +79,7 @@ function mcp_forum_view($id, $mode, $action, $forum_info)
|
||||||
'U_VIEW_FORUM' => append_sid("{$phpbb_root_path}viewforum.$phpEx", 'f=' . $forum_id),
|
'U_VIEW_FORUM' => append_sid("{$phpbb_root_path}viewforum.$phpEx", 'f=' . $forum_id),
|
||||||
'U_VIEW_FORUM_LOGS' => ($auth->acl_gets('a_', 'm_', $forum_id)) ? append_sid("{$phpbb_root_path}mcp.$phpEx", 'i=logs&mode=forum_logs&f=' . $forum_id) : '',
|
'U_VIEW_FORUM_LOGS' => ($auth->acl_gets('a_', 'm_', $forum_id)) ? append_sid("{$phpbb_root_path}mcp.$phpEx", 'i=logs&mode=forum_logs&f=' . $forum_id) : '',
|
||||||
|
|
||||||
'S_MCP_ACTION' => $url . "&i=$id&action=$action&mode=$mode&start=$start" . (($action == 'merge_select') ? $selected_ids : ''),
|
'S_MCP_ACTION' => $url . "&i=$id&mode=$mode&start=$start" . (($action == 'merge_select') ? $selected_ids : ''),
|
||||||
|
|
||||||
'PAGINATION' => generate_pagination($url . "&i=$id&action=$action&mode=$mode" . (($action == 'merge_select') ? $selected_ids : ''), $forum_topics, $topics_per_page, $start),
|
'PAGINATION' => generate_pagination($url . "&i=$id&action=$action&mode=$mode" . (($action == 'merge_select') ? $selected_ids : ''), $forum_topics, $topics_per_page, $start),
|
||||||
'PAGE_NUMBER' => on_page($forum_topics, $topics_per_page, $start),
|
'PAGE_NUMBER' => on_page($forum_topics, $topics_per_page, $start),
|
||||||
|
@ -159,14 +159,13 @@ function mcp_resync_topics($topic_ids)
|
||||||
{
|
{
|
||||||
global $auth, $db, $template, $phpEx, $user, $phpbb_root_path;
|
global $auth, $db, $template, $phpEx, $user, $phpbb_root_path;
|
||||||
|
|
||||||
if (!($forum_id = check_ids($topic_ids, TOPICS_TABLE, 'topic_id', 'm_')))
|
|
||||||
{
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!sizeof($topic_ids))
|
if (!sizeof($topic_ids))
|
||||||
{
|
{
|
||||||
trigger_error($user->lang['NO_TOPIC_SELECTED']);
|
trigger_error($user->lang['NO_TOPIC_SELECTED']);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (check_ids($topic_ids, TOPICS_TABLE, 'topic_id', array('m_')))
|
||||||
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -222,7 +222,7 @@ function mcp_front_view($id, $mode, $action)
|
||||||
'IP' => $row['ip'],
|
'IP' => $row['ip'],
|
||||||
'TIME' => $user->format_date($row['time']),
|
'TIME' => $user->format_date($row['time']),
|
||||||
'ACTION' => $row['action'],
|
'ACTION' => $row['action'],
|
||||||
'U_VIEWTOPIC' => (!empty($row['viewtopic'])) ? $row['viewtopic'] : '',
|
'U_VIEW_TOPIC' => (!empty($row['viewtopic'])) ? $row['viewtopic'] : '',
|
||||||
'U_VIEWLOGS' => (!empty($row['viewlogs'])) ? $row['viewlogs'] : '')
|
'U_VIEWLOGS' => (!empty($row['viewlogs'])) ? $row['viewlogs'] : '')
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -207,7 +207,9 @@ function lock_unlock($action, $ids)
|
||||||
$l_prefix = 'POST';
|
$l_prefix = 'POST';
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!($forum_id = check_ids($ids, $table, $sql_id, array('m_lock'))))
|
$orig_ids = $ids;
|
||||||
|
|
||||||
|
if (!check_ids($ids, $table, $sql_id, array('m_lock')))
|
||||||
{
|
{
|
||||||
// Make sure that for f_user_lock only the lock action is triggered.
|
// Make sure that for f_user_lock only the lock action is triggered.
|
||||||
if ($action != 'lock')
|
if ($action != 'lock')
|
||||||
|
@ -215,13 +217,16 @@ function lock_unlock($action, $ids)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!($forum_id = check_ids($ids, $table, $sql_id, array('f_user_lock'))))
|
$ids = $orig_ids;
|
||||||
|
|
||||||
|
if (!check_ids($ids, $table, $sql_id, array('f_user_lock')))
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
unset($orig_ids);
|
||||||
|
|
||||||
$redirect = request_var('redirect', $user->data['session_page']);
|
$redirect = request_var('redirect', build_url(array('_f_', 'action')));
|
||||||
|
|
||||||
$s_hidden_fields = build_hidden_fields(array(
|
$s_hidden_fields = build_hidden_fields(array(
|
||||||
$sql_id . '_list' => $ids,
|
$sql_id . '_list' => $ids,
|
||||||
|
@ -241,7 +246,7 @@ function lock_unlock($action, $ids)
|
||||||
|
|
||||||
foreach ($data as $id => $row)
|
foreach ($data as $id => $row)
|
||||||
{
|
{
|
||||||
add_log('mod', $forum_id, $row['topic_id'], 'LOG_' . strtoupper($action), $row['topic_title']);
|
add_log('mod', $row['forum_id'], $row['topic_id'], 'LOG_' . strtoupper($action), $row['topic_title']);
|
||||||
}
|
}
|
||||||
|
|
||||||
$success_msg = $l_prefix . ((sizeof($ids) == 1) ? '' : 'S') . '_' . (($action == 'lock' || $action == 'lock_post') ? 'LOCKED' : 'UNLOCKED') . '_SUCCESS';
|
$success_msg = $l_prefix . ((sizeof($ids) == 1) ? '' : 'S') . '_' . (($action == 'lock' || $action == 'lock_post') ? 'LOCKED' : 'UNLOCKED') . '_SUCCESS';
|
||||||
|
@ -272,7 +277,10 @@ function change_topic_type($action, $topic_ids)
|
||||||
{
|
{
|
||||||
global $auth, $user, $db, $phpEx, $phpbb_root_path;
|
global $auth, $user, $db, $phpEx, $phpbb_root_path;
|
||||||
|
|
||||||
if (!($forum_id = check_ids($topic_ids, TOPICS_TABLE, 'topic_id', array('f_announce', 'f_sticky', 'm_'))))
|
// For changing topic types, we only allow operations in one forum.
|
||||||
|
$forum_id = check_ids($topic_ids, TOPICS_TABLE, 'topic_id', array('f_announce', 'f_sticky', 'm_'), true);
|
||||||
|
|
||||||
|
if ($forum_id === false)
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -420,7 +428,10 @@ function mcp_move_topic($topic_ids)
|
||||||
global $auth, $user, $db, $template;
|
global $auth, $user, $db, $template;
|
||||||
global $phpEx, $phpbb_root_path;
|
global $phpEx, $phpbb_root_path;
|
||||||
|
|
||||||
if (!($forum_id = check_ids($topic_ids, TOPICS_TABLE, 'topic_id', 'm_move')))
|
// Here we limit the operation to one forum only
|
||||||
|
$forum_id = check_ids($topic_ids, TOPICS_TABLE, 'topic_id', array('m_move'), true);
|
||||||
|
|
||||||
|
if ($forum_id === false)
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -575,12 +586,13 @@ function mcp_delete_topic($topic_ids)
|
||||||
{
|
{
|
||||||
global $auth, $user, $db, $phpEx, $phpbb_root_path;
|
global $auth, $user, $db, $phpEx, $phpbb_root_path;
|
||||||
|
|
||||||
if (!($forum_id = check_ids($topic_ids, TOPICS_TABLE, 'topic_id', 'm_delete')))
|
if (!check_ids($topic_ids, TOPICS_TABLE, 'topic_id', array('m_delete')))
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$redirect = request_var('redirect', $user->data['session_page']);
|
$redirect = request_var('redirect', build_url(array('_f_', 'action')));
|
||||||
|
$forum_id = request_var('f', 0);
|
||||||
|
|
||||||
$s_hidden_fields = build_hidden_fields(array(
|
$s_hidden_fields = build_hidden_fields(array(
|
||||||
'topic_id_list' => $topic_ids,
|
'topic_id_list' => $topic_ids,
|
||||||
|
@ -598,7 +610,7 @@ function mcp_delete_topic($topic_ids)
|
||||||
|
|
||||||
foreach ($data as $topic_id => $row)
|
foreach ($data as $topic_id => $row)
|
||||||
{
|
{
|
||||||
add_log('mod', $forum_id, 0, 'LOG_TOPIC_DELETED', $row['topic_title']);
|
add_log('mod', $row['forum_id'], 0, 'LOG_TOPIC_DELETED', $row['topic_title']);
|
||||||
}
|
}
|
||||||
|
|
||||||
$return = delete_topics('topic_id', $topic_ids);
|
$return = delete_topics('topic_id', $topic_ids);
|
||||||
|
@ -630,12 +642,13 @@ function mcp_delete_post($post_ids)
|
||||||
{
|
{
|
||||||
global $auth, $user, $db, $phpEx, $phpbb_root_path;
|
global $auth, $user, $db, $phpEx, $phpbb_root_path;
|
||||||
|
|
||||||
if (!($forum_id = check_ids($post_ids, POSTS_TABLE, 'post_id', 'm_delete')))
|
if (!check_ids($post_ids, POSTS_TABLE, 'post_id', array('m_delete')))
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$redirect = request_var('redirect', $user->data['session_page']);
|
$redirect = request_var('redirect', build_url(array('_f_', 'action')));
|
||||||
|
$forum_id = request_var('f', 0);
|
||||||
|
|
||||||
$s_hidden_fields = build_hidden_fields(array(
|
$s_hidden_fields = build_hidden_fields(array(
|
||||||
'post_id_list' => $post_ids,
|
'post_id_list' => $post_ids,
|
||||||
|
@ -649,7 +662,7 @@ function mcp_delete_post($post_ids)
|
||||||
{
|
{
|
||||||
if (!function_exists('delete_posts'))
|
if (!function_exists('delete_posts'))
|
||||||
{
|
{
|
||||||
include_once($phpbb_root_path . 'includes/functions_admin.'.$phpEx);
|
include($phpbb_root_path . 'includes/functions_admin.' . $phpEx);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Count the number of topics that are affected
|
// Count the number of topics that are affected
|
||||||
|
@ -750,13 +763,14 @@ function mcp_fork_topic($topic_ids)
|
||||||
global $auth, $user, $db, $template, $config;
|
global $auth, $user, $db, $template, $config;
|
||||||
global $phpEx, $phpbb_root_path;
|
global $phpEx, $phpbb_root_path;
|
||||||
|
|
||||||
if (!($forum_id = check_ids($topic_ids, TOPICS_TABLE, 'topic_id', 'm_')))
|
if (!check_ids($topic_ids, TOPICS_TABLE, 'topic_id', array('m_')))
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$to_forum_id = request_var('to_forum_id', 0);
|
$to_forum_id = request_var('to_forum_id', 0);
|
||||||
$redirect = request_var('redirect', $user->data['session_page']);
|
$forum_id = request_var('forum_id', 0);
|
||||||
|
$redirect = request_var('redirect', build_url(array('_f_', 'action')));
|
||||||
$additional_msg = $success_msg = '';
|
$additional_msg = $success_msg = '';
|
||||||
|
|
||||||
$s_hidden_fields = build_hidden_fields(array(
|
$s_hidden_fields = build_hidden_fields(array(
|
||||||
|
@ -835,11 +849,6 @@ function mcp_fork_topic($topic_ids)
|
||||||
$new_topic_id = $db->sql_nextid();
|
$new_topic_id = $db->sql_nextid();
|
||||||
$new_topic_id_list[$topic_id] = $new_topic_id;
|
$new_topic_id_list[$topic_id] = $new_topic_id;
|
||||||
|
|
||||||
/**
|
|
||||||
* @todo enable? (is this still needed?)
|
|
||||||
* markread('topic', $to_forum_id, $new_topic_id);
|
|
||||||
*/
|
|
||||||
|
|
||||||
if ($topic_row['poll_start'])
|
if ($topic_row['poll_start'])
|
||||||
{
|
{
|
||||||
$poll_rows = array();
|
$poll_rows = array();
|
||||||
|
|
|
@ -248,7 +248,7 @@ class mcp_queue
|
||||||
|
|
||||||
if (sizeof($post_ids))
|
if (sizeof($post_ids))
|
||||||
{
|
{
|
||||||
$sql = 'SELECT t.topic_id, t.topic_title, t.forum_id, p.post_id, p.post_subject, p.post_username, p.poster_id, p.post_time, u.username
|
$sql = 'SELECT t.topic_id, t.topic_title, t.forum_id, p.post_id, p.post_subject, p.post_username, p.poster_id, p.post_time, u.username, u.user_colour
|
||||||
FROM ' . POSTS_TABLE . ' p, ' . TOPICS_TABLE . ' t, ' . USERS_TABLE . ' u
|
FROM ' . POSTS_TABLE . ' p, ' . TOPICS_TABLE . ' t, ' . USERS_TABLE . ' u
|
||||||
WHERE ' . $db->sql_in_set('p.post_id', $post_ids) . '
|
WHERE ' . $db->sql_in_set('p.post_id', $post_ids) . '
|
||||||
AND t.topic_id = p.topic_id
|
AND t.topic_id = p.topic_id
|
||||||
|
@ -279,7 +279,7 @@ class mcp_queue
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
$sql = 'SELECT t.forum_id, t.topic_id, t.topic_title, t.topic_title AS post_subject, t.topic_time AS post_time, t.topic_poster AS poster_id, t.topic_first_post_id AS post_id, t.topic_first_poster_name AS username
|
$sql = 'SELECT t.forum_id, t.topic_id, t.topic_title, t.topic_title AS post_subject, t.topic_time AS post_time, t.topic_poster AS poster_id, t.topic_first_post_id AS post_id, t.topic_first_poster_name AS username, t.topic_first_poster_colour AS user_colour
|
||||||
FROM ' . TOPICS_TABLE . " t
|
FROM ' . TOPICS_TABLE . " t
|
||||||
WHERE forum_id IN (0, $forum_list)
|
WHERE forum_id IN (0, $forum_list)
|
||||||
AND topic_approved = 0
|
AND topic_approved = 0
|
||||||
|
@ -323,6 +323,11 @@ class mcp_queue
|
||||||
$row['forum_id'] = $global_id;
|
$row['forum_id'] = $global_id;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (empty($row['post_username']))
|
||||||
|
{
|
||||||
|
$row['post_username'] = $user->lang['GUEST'];
|
||||||
|
}
|
||||||
|
|
||||||
$template->assign_block_vars('postrow', array(
|
$template->assign_block_vars('postrow', array(
|
||||||
'U_VIEWFORUM' => (!$global_topic) ? append_sid("{$phpbb_root_path}viewforum.$phpEx", 'f=' . $row['forum_id']) : '',
|
'U_VIEWFORUM' => (!$global_topic) ? append_sid("{$phpbb_root_path}viewforum.$phpEx", 'f=' . $row['forum_id']) : '',
|
||||||
'U_VIEWPOST' => append_sid("{$phpbb_root_path}viewtopic.$phpEx", 'f=' . $row['forum_id'] . '&p=' . $row['post_id']) . (($mode == 'unapproved_posts') ? '#p' . $row['post_id'] : ''),
|
'U_VIEWPOST' => append_sid("{$phpbb_root_path}viewtopic.$phpEx", 'f=' . $row['forum_id'] . '&p=' . $row['post_id']) . (($mode == 'unapproved_posts') ? '#p' . $row['post_id'] : ''),
|
||||||
|
@ -372,19 +377,18 @@ function approve_post($post_id_list, $mode)
|
||||||
global $db, $template, $user, $config;
|
global $db, $template, $user, $config;
|
||||||
global $phpEx, $phpbb_root_path;
|
global $phpEx, $phpbb_root_path;
|
||||||
|
|
||||||
if (!($forum_id = check_ids($post_id_list, POSTS_TABLE, 'post_id', 'm_approve')))
|
if (!check_ids($post_id_list, POSTS_TABLE, 'post_id', array('m_approve')))
|
||||||
{
|
{
|
||||||
trigger_error('NOT_AUTHORIZED');
|
trigger_error('NOT_AUTHORIZED');
|
||||||
}
|
}
|
||||||
|
|
||||||
$redirect = request_var('redirect', $user->data['session_page']);
|
$redirect = request_var('redirect', build_url(array('_f_')));
|
||||||
$success_msg = '';
|
$success_msg = '';
|
||||||
|
|
||||||
$s_hidden_fields = build_hidden_fields(array(
|
$s_hidden_fields = build_hidden_fields(array(
|
||||||
'i' => 'queue',
|
'i' => 'queue',
|
||||||
'mode' => $mode,
|
'mode' => $mode,
|
||||||
'post_id_list' => $post_id_list,
|
'post_id_list' => $post_id_list,
|
||||||
'f' => $forum_id,
|
|
||||||
'action' => 'approve',
|
'action' => 'approve',
|
||||||
'redirect' => $redirect)
|
'redirect' => $redirect)
|
||||||
);
|
);
|
||||||
|
@ -398,8 +402,8 @@ function approve_post($post_id_list, $mode)
|
||||||
// If Topic -> total_topics = total_topics+1, total_posts = total_posts+1, forum_topics = forum_topics+1, forum_posts = forum_posts+1
|
// If Topic -> total_topics = total_topics+1, total_posts = total_posts+1, forum_topics = forum_topics+1, forum_posts = forum_posts+1
|
||||||
// If Post -> total_posts = total_posts+1, forum_posts = forum_posts+1, topic_replies = topic_replies+1
|
// If Post -> total_posts = total_posts+1, forum_posts = forum_posts+1, topic_replies = topic_replies+1
|
||||||
|
|
||||||
$total_topics = $total_posts = $forum_topics = $forum_posts = 0;
|
$total_topics = $total_posts = 0;
|
||||||
$topic_approve_sql = $topic_replies_sql = $post_approve_sql = $topic_id_list = array();
|
$forum_topics_posts = $topic_approve_sql = $topic_replies_sql = $post_approve_sql = $topic_id_list = $forum_id_list = array();
|
||||||
|
|
||||||
$update_forum_information = false;
|
$update_forum_information = false;
|
||||||
|
|
||||||
|
@ -407,13 +411,26 @@ function approve_post($post_id_list, $mode)
|
||||||
{
|
{
|
||||||
$topic_id_list[$post_data['topic_id']] = 1;
|
$topic_id_list[$post_data['topic_id']] = 1;
|
||||||
|
|
||||||
|
if ($post_data['forum_id'])
|
||||||
|
{
|
||||||
|
$forum_id_list[$post_data['forum_id']] = 1;
|
||||||
|
}
|
||||||
|
|
||||||
// Topic or Post. ;)
|
// Topic or Post. ;)
|
||||||
if ($post_data['topic_first_post_id'] == $post_id)
|
if ($post_data['topic_first_post_id'] == $post_id)
|
||||||
{
|
{
|
||||||
if ($post_data['forum_id'])
|
if ($post_data['forum_id'])
|
||||||
{
|
{
|
||||||
|
if (!isset($forum_topics_posts[$post_data['forum_id']]))
|
||||||
|
{
|
||||||
|
$forum_topics_posts[$post_data['forum_id']] = array(
|
||||||
|
'forum_posts' => 0,
|
||||||
|
'forum_topics' => 0
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
$total_topics++;
|
$total_topics++;
|
||||||
$forum_topics++;
|
$forum_topics_posts[$post_data['forum_id']]['forum_topics']++;
|
||||||
}
|
}
|
||||||
|
|
||||||
$topic_approve_sql[] = $post_data['topic_id'];
|
$topic_approve_sql[] = $post_data['topic_id'];
|
||||||
|
@ -422,18 +439,23 @@ function approve_post($post_id_list, $mode)
|
||||||
{
|
{
|
||||||
if (!isset($topic_replies_sql[$post_data['topic_id']]))
|
if (!isset($topic_replies_sql[$post_data['topic_id']]))
|
||||||
{
|
{
|
||||||
$topic_replies_sql[$post_data['topic_id']] = 1;
|
$topic_replies_sql[$post_data['topic_id']] = 0;
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
$topic_replies_sql[$post_data['topic_id']]++;
|
|
||||||
}
|
}
|
||||||
|
$topic_replies_sql[$post_data['topic_id']]++;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($post_data['forum_id'])
|
if ($post_data['forum_id'])
|
||||||
{
|
{
|
||||||
|
if (!isset($forum_topics_posts[$post_data['forum_id']]))
|
||||||
|
{
|
||||||
|
$forum_topics_posts[$post_data['forum_id']] = array(
|
||||||
|
'forum_posts' => 0,
|
||||||
|
'forum_topics' => 0
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
$total_posts++;
|
$total_posts++;
|
||||||
$forum_posts++;
|
$forum_topics_posts[$post_data['forum_id']]['forum_posts']++;
|
||||||
}
|
}
|
||||||
|
|
||||||
$post_approve_sql[] = $post_id;
|
$post_approve_sql[] = $post_id;
|
||||||
|
@ -472,16 +494,19 @@ function approve_post($post_id_list, $mode)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($forum_topics || $forum_posts)
|
if (sizeof($forum_topics_posts))
|
||||||
{
|
{
|
||||||
$sql = 'UPDATE ' . FORUMS_TABLE . '
|
foreach ($forum_topics_posts as $forum_id => $row)
|
||||||
SET ';
|
{
|
||||||
$sql .= ($forum_topics) ? "forum_topics = forum_topics + $forum_topics" : '';
|
$sql = 'UPDATE ' . FORUMS_TABLE . '
|
||||||
$sql .= ($forum_topics && $forum_posts) ? ', ' : '';
|
SET ';
|
||||||
$sql .= ($forum_posts) ? "forum_posts = forum_posts + $forum_posts" : '';
|
$sql .= ($row['forum_topics']) ? "forum_topics = forum_topics + {$row['forum_topics']}" : '';
|
||||||
$sql .= " WHERE forum_id = $forum_id";
|
$sql .= ($row['forum_topics'] && $row['forum_posts']) ? ', ' : '';
|
||||||
|
$sql .= ($row['forum_posts']) ? "forum_posts = forum_posts + {$row['forum_posts']}" : '';
|
||||||
|
$sql .= " WHERE forum_id = $forum_id";
|
||||||
|
|
||||||
$db->sql_query($sql);
|
$db->sql_query($sql);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($total_topics)
|
if ($total_topics)
|
||||||
|
@ -499,9 +524,9 @@ function approve_post($post_id_list, $mode)
|
||||||
|
|
||||||
if ($update_forum_information)
|
if ($update_forum_information)
|
||||||
{
|
{
|
||||||
update_post_information('forum', $forum_id);
|
update_post_information('forum', array_keys($forum_id_list));
|
||||||
}
|
}
|
||||||
unset($topic_id_list);
|
unset($topic_id_list, $forum_id_list);
|
||||||
|
|
||||||
$messenger = new messenger();
|
$messenger = new messenger();
|
||||||
|
|
||||||
|
@ -528,8 +553,8 @@ function approve_post($post_id_list, $mode)
|
||||||
'POST_SUBJECT' => htmlspecialchars_decode(censor_text($post_data['post_subject'])),
|
'POST_SUBJECT' => htmlspecialchars_decode(censor_text($post_data['post_subject'])),
|
||||||
'TOPIC_TITLE' => htmlspecialchars_decode(censor_text($post_data['topic_title'])),
|
'TOPIC_TITLE' => htmlspecialchars_decode(censor_text($post_data['topic_title'])),
|
||||||
|
|
||||||
'U_VIEW_TOPIC' => generate_board_url() . "/viewtopic.$phpEx?f=$forum_id&t={$post_data['topic_id']}&e=0",
|
'U_VIEW_TOPIC' => generate_board_url() . "/viewtopic.$phpEx?f={$post_data['forum_id']}&t={$post_data['topic_id']}&e=0",
|
||||||
'U_VIEW_POST' => generate_board_url() . "/viewtopic.$phpEx?f=$forum_id&t={$post_data['topic_id']}&p=$post_id&e=$post_id")
|
'U_VIEW_POST' => generate_board_url() . "/viewtopic.$phpEx?f={$post_data['forum_id']}&t={$post_data['topic_id']}&p=$post_id&e=$post_id")
|
||||||
);
|
);
|
||||||
|
|
||||||
$messenger->send($post_data['user_notify_type']);
|
$messenger->send($post_data['user_notify_type']);
|
||||||
|
@ -547,19 +572,19 @@ function approve_post($post_id_list, $mode)
|
||||||
if ($post_id == $post_data['topic_first_post_id'] && $post_id == $post_data['topic_last_post_id'])
|
if ($post_id == $post_data['topic_first_post_id'] && $post_id == $post_data['topic_last_post_id'])
|
||||||
{
|
{
|
||||||
// Forum Notifications
|
// Forum Notifications
|
||||||
user_notification('post', $post_data['topic_title'], $post_data['topic_title'], $post_data['forum_name'], $forum_id, $post_data['topic_id'], $post_id);
|
user_notification('post', $post_data['topic_title'], $post_data['topic_title'], $post_data['forum_name'], $post_data['forum_id'], $post_data['topic_id'], $post_id);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// Topic Notifications
|
// Topic Notifications
|
||||||
user_notification('reply', $post_data['post_subject'], $post_data['topic_title'], $post_data['forum_name'], $forum_id, $post_data['topic_id'], $post_id);
|
user_notification('reply', $post_data['post_subject'], $post_data['topic_title'], $post_data['forum_name'], $post_data['forum_id'], $post_data['topic_id'], $post_id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
unset($post_info);
|
unset($post_info);
|
||||||
|
|
||||||
if ($forum_topics)
|
if ($total_topics)
|
||||||
{
|
{
|
||||||
$success_msg = ($forum_topics == 1) ? 'TOPIC_APPROVED_SUCCESS' : 'TOPICS_APPROVED_SUCCESS';
|
$success_msg = ($total_topics == 1) ? 'TOPIC_APPROVED_SUCCESS' : 'TOPICS_APPROVED_SUCCESS';
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -598,12 +623,12 @@ function disapprove_post($post_id_list, $mode)
|
||||||
global $db, $template, $user, $config;
|
global $db, $template, $user, $config;
|
||||||
global $phpEx, $phpbb_root_path;
|
global $phpEx, $phpbb_root_path;
|
||||||
|
|
||||||
if (!($forum_id = check_ids($post_id_list, POSTS_TABLE, 'post_id', 'm_approve')))
|
if (!check_ids($post_id_list, POSTS_TABLE, 'post_id', array('m_approve')))
|
||||||
{
|
{
|
||||||
trigger_error('NOT_AUTHORIZED');
|
trigger_error('NOT_AUTHORIZED');
|
||||||
}
|
}
|
||||||
|
|
||||||
$redirect = request_var('redirect', build_url(array('t', 'mode')) . '&mode=unapproved_topics');
|
$redirect = request_var('redirect', build_url(array('t', 'mode', '_f_')) . '&mode=unapproved_topics');
|
||||||
$reason = request_var('reason', '', true);
|
$reason = request_var('reason', '', true);
|
||||||
$reason_id = request_var('reason_id', 0);
|
$reason_id = request_var('reason_id', 0);
|
||||||
$success_msg = $additional_msg = '';
|
$success_msg = $additional_msg = '';
|
||||||
|
@ -612,7 +637,6 @@ function disapprove_post($post_id_list, $mode)
|
||||||
'i' => 'queue',
|
'i' => 'queue',
|
||||||
'mode' => $mode,
|
'mode' => $mode,
|
||||||
'post_id_list' => $post_id_list,
|
'post_id_list' => $post_id_list,
|
||||||
'f' => $forum_id,
|
|
||||||
'action' => 'disapprove',
|
'action' => 'disapprove',
|
||||||
'redirect' => $redirect)
|
'redirect' => $redirect)
|
||||||
);
|
);
|
||||||
|
@ -649,42 +673,52 @@ function disapprove_post($post_id_list, $mode)
|
||||||
// If Topic -> forum_topics_real -= 1
|
// If Topic -> forum_topics_real -= 1
|
||||||
// If Post -> topic_replies_real -= 1
|
// If Post -> topic_replies_real -= 1
|
||||||
|
|
||||||
$forum_topics_real = 0;
|
$num_disapproved = 0;
|
||||||
$topic_replies_real_sql = $post_disapprove_sql = $topic_id_list = array();
|
$forum_topics_real = $topic_id_list = $forum_id_list = $topic_replies_real_sql = $post_disapprove_sql = array();
|
||||||
|
|
||||||
foreach ($post_info as $post_id => $post_data)
|
foreach ($post_info as $post_id => $post_data)
|
||||||
{
|
{
|
||||||
$topic_id_list[$post_data['topic_id']] = 1;
|
$topic_id_list[$post_data['topic_id']] = 1;
|
||||||
|
|
||||||
|
if ($post_data['forum_id'])
|
||||||
|
{
|
||||||
|
$forum_id_list[$post_data['forum_id']] = 1;
|
||||||
|
}
|
||||||
|
|
||||||
// Topic or Post. ;)
|
// Topic or Post. ;)
|
||||||
if ($post_data['topic_first_post_id'] == $post_id && $post_data['topic_last_post_id'] == $post_id)
|
if ($post_data['topic_first_post_id'] == $post_id && $post_data['topic_last_post_id'] == $post_id)
|
||||||
{
|
{
|
||||||
if ($post_data['forum_id'])
|
if ($post_data['forum_id'])
|
||||||
{
|
{
|
||||||
$forum_topics_real++;
|
if (!isset($forum_topics_real[$post_data['forum_id']]))
|
||||||
|
{
|
||||||
|
$forum_topics_real[$post_data['forum_id']] = 0;
|
||||||
|
}
|
||||||
|
$forum_topics_real[$post_data['forum_id']]++;
|
||||||
|
$num_disapproved++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (!isset($topic_replies_real_sql[$post_data['topic_id']]))
|
if (!isset($topic_replies_real_sql[$post_data['topic_id']]))
|
||||||
{
|
{
|
||||||
$topic_replies_real_sql[$post_data['topic_id']] = 1;
|
$topic_replies_real_sql[$post_data['topic_id']] = 0;
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
$topic_replies_real_sql[$post_data['topic_id']]++;
|
|
||||||
}
|
}
|
||||||
|
$topic_replies_real_sql[$post_data['topic_id']]++;
|
||||||
}
|
}
|
||||||
|
|
||||||
$post_disapprove_sql[] = $post_id;
|
$post_disapprove_sql[] = $post_id;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($forum_topics_real)
|
if (sizeof($forum_topics_real))
|
||||||
{
|
{
|
||||||
$sql = 'UPDATE ' . FORUMS_TABLE . "
|
foreach ($forum_topics_real as $forum_id => $topics_real)
|
||||||
SET forum_topics_real = forum_topics_real - $forum_topics_real
|
{
|
||||||
WHERE forum_id = $forum_id";
|
$sql = 'UPDATE ' . FORUMS_TABLE . "
|
||||||
$db->sql_query($sql);
|
SET forum_topics_real = forum_topics_real - $topics_real
|
||||||
|
WHERE forum_id = $forum_id";
|
||||||
|
$db->sql_query($sql);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (sizeof($topic_replies_real_sql))
|
if (sizeof($topic_replies_real_sql))
|
||||||
|
@ -711,8 +745,12 @@ function disapprove_post($post_id_list, $mode)
|
||||||
unset($post_disapprove_sql, $topic_replies_real_sql);
|
unset($post_disapprove_sql, $topic_replies_real_sql);
|
||||||
|
|
||||||
update_post_information('topic', array_keys($topic_id_list));
|
update_post_information('topic', array_keys($topic_id_list));
|
||||||
update_post_information('forum', $forum_id);
|
|
||||||
unset($topic_id_list);
|
if (sizeof($forum_id_list))
|
||||||
|
{
|
||||||
|
update_post_information('forum', array_keys($forum_id_list));
|
||||||
|
}
|
||||||
|
unset($topic_id_list, $forum_id_list);
|
||||||
|
|
||||||
$messenger = new messenger();
|
$messenger = new messenger();
|
||||||
|
|
||||||
|
@ -749,9 +787,9 @@ function disapprove_post($post_id_list, $mode)
|
||||||
}
|
}
|
||||||
unset($post_info, $disapprove_reason);
|
unset($post_info, $disapprove_reason);
|
||||||
|
|
||||||
if ($forum_topics_real)
|
if (sizeof($forum_topics_real))
|
||||||
{
|
{
|
||||||
$success_msg = ($forum_topics_real == 1) ? 'TOPIC_DISAPPROVED_SUCCESS' : 'TOPICS_DISAPPROVED_SUCCESS';
|
$success_msg = ($num_disapproved == 1) ? 'TOPIC_DISAPPROVED_SUCCESS' : 'TOPICS_DISAPPROVED_SUCCESS';
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|
|
@ -107,14 +107,6 @@ class mcp_reports
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Set some vars
|
|
||||||
if ($post_info['user_id'] == ANONYMOUS)
|
|
||||||
{
|
|
||||||
$poster = ($post_info['post_username']) ? $post_info['post_username'] : $user->lang['GUEST'];
|
|
||||||
}
|
|
||||||
|
|
||||||
$poster = ($post_info['user_colour']) ? '<span style="color:#' . $post_info['user_colour'] . '">' . $post_info['username'] . '</span>' : $post_info['username'];
|
|
||||||
|
|
||||||
// Process message, leave it uncensored
|
// Process message, leave it uncensored
|
||||||
$message = $post_info['post_text'];
|
$message = $post_info['post_text'];
|
||||||
$message = str_replace("\n", '<br />', $message);
|
$message = str_replace("\n", '<br />', $message);
|
||||||
|
@ -129,7 +121,7 @@ class mcp_reports
|
||||||
|
|
||||||
$template->assign_vars(array(
|
$template->assign_vars(array(
|
||||||
'S_MCP_REPORT' => true,
|
'S_MCP_REPORT' => true,
|
||||||
'S_CLOSE_ACTION' => append_sid("{$phpbb_root_path}mcp.$phpEx", "i=reports&p=$post_id&f=$forum_id"),
|
'S_CLOSE_ACTION' => $this->u_action . '&p=' . $post_id . 'f=' . $forum_id,
|
||||||
'S_CAN_VIEWIP' => $auth->acl_get('m_info', $post_info['forum_id']),
|
'S_CAN_VIEWIP' => $auth->acl_get('m_info', $post_info['forum_id']),
|
||||||
'S_POST_REPORTED' => $post_info['post_reported'],
|
'S_POST_REPORTED' => $post_info['post_reported'],
|
||||||
'S_POST_UNAPPROVED' => !$post_info['post_approved'],
|
'S_POST_UNAPPROVED' => !$post_info['post_approved'],
|
||||||
|
@ -150,7 +142,7 @@ class mcp_reports
|
||||||
'EDIT_IMG' => $user->img('icon_post_edit', $user->lang['EDIT_POST']),
|
'EDIT_IMG' => $user->img('icon_post_edit', $user->lang['EDIT_POST']),
|
||||||
'UNAPPROVED_IMG' => $user->img('icon_topic_unapproved', $user->lang['POST_UNAPPROVED']),
|
'UNAPPROVED_IMG' => $user->img('icon_topic_unapproved', $user->lang['POST_UNAPPROVED']),
|
||||||
|
|
||||||
'RETURN_REPORTS' => sprintf($user->lang['RETURN_REPORTS'], '<a href="' . append_sid("{$phpbb_root_path}mcp.$phpEx", 'i=reports' . (($post_info['post_reported']) ? '&mode=reports' : '&mode=reports_closed') . '&start=' . $start) . '">', '</a>'),
|
'RETURN_REPORTS' => sprintf($user->lang['RETURN_REPORTS'], '<a href="' . append_sid("{$phpbb_root_path}mcp.$phpEx", 'i=reports' . (($post_info['post_reported']) ? '&mode=reports' : '&mode=reports_closed') . '&start=' . $start . '&f=' . $post_info['forum_id']) . '">', '</a>'),
|
||||||
'REPORTED_IMG' => $user->img('icon_topic_reported', $user->lang['POST_REPORTED']),
|
'REPORTED_IMG' => $user->img('icon_topic_reported', $user->lang['POST_REPORTED']),
|
||||||
'REPORT_REASON_TITLE' => $reason['title'],
|
'REPORT_REASON_TITLE' => $reason['title'],
|
||||||
'REPORT_REASON_DESCRIPTION' => $reason['description'],
|
'REPORT_REASON_DESCRIPTION' => $reason['description'],
|
||||||
|
@ -284,7 +276,7 @@ class mcp_reports
|
||||||
|
|
||||||
if (sizeof($report_ids))
|
if (sizeof($report_ids))
|
||||||
{
|
{
|
||||||
$sql = 'SELECT t.forum_id, t.topic_id, t.topic_title, p.post_id, p.post_subject, p.post_username, p.poster_id, p.post_time, u.username, r.user_id as reporter_id, ru.username as reporter_name, r.report_time, r.report_id
|
$sql = 'SELECT t.forum_id, t.topic_id, t.topic_title, p.post_id, p.post_subject, p.post_username, p.poster_id, p.post_time, u.username, u.user_colour, r.user_id as reporter_id, ru.username as reporter_name, ru.user_colour as reporter_colour, r.report_time, r.report_id
|
||||||
FROM ' . REPORTS_TABLE . ' r, ' . POSTS_TABLE . ' p, ' . TOPICS_TABLE . ' t, ' . USERS_TABLE . ' u, ' . USERS_TABLE . ' ru
|
FROM ' . REPORTS_TABLE . ' r, ' . POSTS_TABLE . ' p, ' . TOPICS_TABLE . ' t, ' . USERS_TABLE . ' u, ' . USERS_TABLE . ' ru
|
||||||
WHERE ' . $db->sql_in_set('r.report_id', $report_ids) . '
|
WHERE ' . $db->sql_in_set('r.report_id', $report_ids) . '
|
||||||
AND t.topic_id = p.topic_id
|
AND t.topic_id = p.topic_id
|
||||||
|
@ -306,18 +298,21 @@ class mcp_reports
|
||||||
'U_VIEWFORUM' => (!$global_topic) ? append_sid("{$phpbb_root_path}viewforum.$phpEx", 'f=' . $row['forum_id']) : '',
|
'U_VIEWFORUM' => (!$global_topic) ? append_sid("{$phpbb_root_path}viewforum.$phpEx", 'f=' . $row['forum_id']) : '',
|
||||||
'U_VIEWPOST' => append_sid("{$phpbb_root_path}viewtopic.$phpEx", 'f=' . $row['forum_id'] . '&p=' . $row['post_id']) . '#p' . $row['post_id'],
|
'U_VIEWPOST' => append_sid("{$phpbb_root_path}viewtopic.$phpEx", 'f=' . $row['forum_id'] . '&p=' . $row['post_id']) . '#p' . $row['post_id'],
|
||||||
'U_VIEW_DETAILS' => append_sid("{$phpbb_root_path}mcp.$phpEx", "i=reports&start=$start&mode=report_details&f={$row['forum_id']}&r={$row['report_id']}"),
|
'U_VIEW_DETAILS' => append_sid("{$phpbb_root_path}mcp.$phpEx", "i=reports&start=$start&mode=report_details&f={$row['forum_id']}&r={$row['report_id']}"),
|
||||||
'U_VIEW_REPORTER_PROFILE' => ($row['reporter_id'] != ANONYMOUS) ? append_sid("{$phpbb_root_path}memberlist.$phpEx", 'mode=viewprofile&u=' . $row['reporter_id']) : '',
|
|
||||||
|
|
||||||
'POST_AUTHOR_FULL' => get_username_string('full', $row['poster_id'], $row['username'], $row['user_colour'], $row['post_username']),
|
'POST_AUTHOR_FULL' => get_username_string('full', $row['poster_id'], $row['username'], $row['user_colour'], $row['post_username']),
|
||||||
'POST_AUTHOR_COLOUR' => get_username_string('colour', $row['poster_id'], $row['username'], $row['user_colour'], $row['post_username']),
|
'POST_AUTHOR_COLOUR' => get_username_string('colour', $row['poster_id'], $row['username'], $row['user_colour'], $row['post_username']),
|
||||||
'POST_AUTHOR' => get_username_string('username', $row['poster_id'], $row['username'], $row['user_colour'], $row['post_username']),
|
'POST_AUTHOR' => get_username_string('username', $row['poster_id'], $row['username'], $row['user_colour'], $row['post_username']),
|
||||||
'U_POST_AUTHOR' => get_username_string('profile', $row['poster_id'], $row['username'], $row['user_colour'], $row['post_username']),
|
'U_POST_AUTHOR' => get_username_string('profile', $row['poster_id'], $row['username'], $row['user_colour'], $row['post_username']),
|
||||||
|
|
||||||
|
'REPORTER_FULL' => get_username_string('full', $row['reporter_id'], $row['reporter_name'], $row['reporter_colour']),
|
||||||
|
'REPORTER_COLOUR' => get_username_string('colour', $row['reporter_id'], $row['reporter_name'], $row['reporter_colour']),
|
||||||
|
'REPORTER' => get_username_string('username', $row['reporter_id'], $row['reporter_name'], $row['reporter_colour']),
|
||||||
|
'U_REPORTER' => get_username_string('profile', $row['reporter_id'], $row['reporter_name'], $row['reporter_colour']),
|
||||||
|
|
||||||
'FORUM_NAME' => (!$global_topic) ? $forum_data[$row['forum_id']]['forum_name'] : $user->lang['GLOBAL_ANNOUNCEMENT'],
|
'FORUM_NAME' => (!$global_topic) ? $forum_data[$row['forum_id']]['forum_name'] : $user->lang['GLOBAL_ANNOUNCEMENT'],
|
||||||
'POST_ID' => $row['post_id'],
|
'POST_ID' => $row['post_id'],
|
||||||
'POST_SUBJECT' => $row['post_subject'],
|
'POST_SUBJECT' => $row['post_subject'],
|
||||||
'POST_TIME' => $user->format_date($row['post_time']),
|
'POST_TIME' => $user->format_date($row['post_time']),
|
||||||
'REPORTER' => ($row['reporter_id'] == ANONYMOUS) ? $user->lang['GUEST'] : $row['reporter_name'],
|
|
||||||
'REPORT_TIME' => $user->format_date($row['report_time']),
|
'REPORT_TIME' => $user->format_date($row['report_time']),
|
||||||
'TOPIC_TITLE' => $row['topic_title'])
|
'TOPIC_TITLE' => $row['topic_title'])
|
||||||
);
|
);
|
||||||
|
@ -332,7 +327,7 @@ class mcp_reports
|
||||||
'L_TITLE' => ($mode == 'reports') ? $user->lang['MCP_REPORTS_OPEN'] : $user->lang['MCP_REPORTS_CLOSED'],
|
'L_TITLE' => ($mode == 'reports') ? $user->lang['MCP_REPORTS_OPEN'] : $user->lang['MCP_REPORTS_CLOSED'],
|
||||||
'L_ONLY_TOPIC' => ($topic_id) ? sprintf($user->lang['ONLY_TOPIC'], $topic_info['topic_title']) : '',
|
'L_ONLY_TOPIC' => ($topic_id) ? sprintf($user->lang['ONLY_TOPIC'], $topic_info['topic_title']) : '',
|
||||||
|
|
||||||
'S_MCP_ACTION' => build_url(array('t', 'f', 'sd', 'st', 'sk')),
|
'S_MCP_ACTION' => $this->u_action,
|
||||||
'S_FORUM_OPTIONS' => $forum_options,
|
'S_FORUM_OPTIONS' => $forum_options,
|
||||||
'S_CLOSED' => ($mode == 'reports_closed') ? true : false,
|
'S_CLOSED' => ($mode == 'reports_closed') ? true : false,
|
||||||
|
|
||||||
|
@ -356,18 +351,18 @@ function close_report($post_id_list, $mode, $action)
|
||||||
global $db, $template, $user, $config;
|
global $db, $template, $user, $config;
|
||||||
global $phpEx, $phpbb_root_path;
|
global $phpEx, $phpbb_root_path;
|
||||||
|
|
||||||
if (!($forum_id = check_ids($post_id_list, POSTS_TABLE, 'post_id', 'm_report')))
|
if (!check_ids($post_id_list, POSTS_TABLE, 'post_id', array('m_report')))
|
||||||
{
|
{
|
||||||
trigger_error('NOT_AUTHORIZED');
|
trigger_error('NOT_AUTHORIZED');
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($action == 'delete' && strpos($user->data['session_page'], 'mode=report_details') !== false)
|
if ($action == 'delete' && strpos($user->data['session_page'], 'mode=report_details') !== false)
|
||||||
{
|
{
|
||||||
$redirect = request_var('redirect', build_url(array('mode')) . '&mode=reports');
|
$redirect = request_var('redirect', build_url(array('mode', '_f_', 'r')) . '&mode=reports');
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
$redirect = request_var('redirect', $user->data['session_page']);
|
$redirect = request_var('redirect', build_url(array('_f_')));
|
||||||
}
|
}
|
||||||
$success_msg = '';
|
$success_msg = '';
|
||||||
|
|
||||||
|
@ -375,7 +370,6 @@ function close_report($post_id_list, $mode, $action)
|
||||||
'i' => 'reports',
|
'i' => 'reports',
|
||||||
'mode' => $mode,
|
'mode' => $mode,
|
||||||
'post_id_list' => $post_id_list,
|
'post_id_list' => $post_id_list,
|
||||||
'f' => $forum_id,
|
|
||||||
'action' => $action,
|
'action' => $action,
|
||||||
'redirect' => $redirect)
|
'redirect' => $redirect)
|
||||||
);
|
);
|
||||||
|
|
|
@ -179,7 +179,7 @@ function mcp_topic_view($id, $mode, $action)
|
||||||
|
|
||||||
$template->assign_vars(array(
|
$template->assign_vars(array(
|
||||||
'TOPIC_TITLE' => $topic_info['topic_title'],
|
'TOPIC_TITLE' => $topic_info['topic_title'],
|
||||||
'U_VIEWTOPIC' => append_sid("{$phpbb_root_path}viewtopic.$phpEx", 'f=' . $topic_info['forum_id'] . '&t=' . $topic_info['topic_id']),
|
'U_VIEW_TOPIC' => append_sid("{$phpbb_root_path}viewtopic.$phpEx", 'f=' . $topic_info['forum_id'] . '&t=' . $topic_info['topic_id']),
|
||||||
|
|
||||||
'TO_TOPIC_ID' => $to_topic_id,
|
'TO_TOPIC_ID' => $to_topic_id,
|
||||||
'TO_TOPIC_INFO' => ($to_topic_id) ? sprintf($user->lang['YOU_SELECTED_TOPIC'], $to_topic_id, '<a href="' . append_sid("{$phpbb_root_path}viewtopic.$phpEx", 'f=' . $to_topic_info['forum_id'] . '&t=' . $to_topic_id) . '">' . $to_topic_info['topic_title'] . '</a>') : '',
|
'TO_TOPIC_INFO' => ($to_topic_id) ? sprintf($user->lang['YOU_SELECTED_TOPIC'], $to_topic_id, '<a href="' . append_sid("{$phpbb_root_path}viewtopic.$phpEx", 'f=' . $to_topic_info['forum_id'] . '&t=' . $to_topic_id) . '">' . $to_topic_info['topic_title'] . '</a>') : '',
|
||||||
|
@ -223,6 +223,7 @@ function split_topic($action, $topic_id, $to_forum_id, $subject)
|
||||||
global $db, $template, $user, $phpEx, $phpbb_root_path, $auth;
|
global $db, $template, $user, $phpEx, $phpbb_root_path, $auth;
|
||||||
|
|
||||||
$post_id_list = request_var('post_id_list', array(0));
|
$post_id_list = request_var('post_id_list', array(0));
|
||||||
|
$forum_id = request_var('forum_id', 0);
|
||||||
$start = request_var('start', 0);
|
$start = request_var('start', 0);
|
||||||
|
|
||||||
if (!sizeof($post_id_list))
|
if (!sizeof($post_id_list))
|
||||||
|
@ -231,7 +232,7 @@ function split_topic($action, $topic_id, $to_forum_id, $subject)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!($forum_id = check_ids($post_id_list, POSTS_TABLE, 'post_id', 'm_split')))
|
if (!check_ids($post_id_list, POSTS_TABLE, 'post_id', array('m_split')))
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -430,7 +431,7 @@ function merge_posts($topic_id, $to_topic_id)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!($forum_id = check_ids($post_id_list, POSTS_TABLE, 'post_id', 'm_merge')))
|
if (!check_ids($post_id_list, POSTS_TABLE, 'post_id', array('m_merge')))
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -445,7 +446,6 @@ function merge_posts($topic_id, $to_topic_id)
|
||||||
'action' => 'merge_posts',
|
'action' => 'merge_posts',
|
||||||
'start' => $start,
|
'start' => $start,
|
||||||
'redirect' => $redirect,
|
'redirect' => $redirect,
|
||||||
'f' => $forum_id,
|
|
||||||
't' => $topic_id)
|
't' => $topic_id)
|
||||||
);
|
);
|
||||||
$success_msg = $return_link = '';
|
$success_msg = $return_link = '';
|
||||||
|
@ -465,7 +465,7 @@ function merge_posts($topic_id, $to_topic_id)
|
||||||
|
|
||||||
if (sizeof($topic_data))
|
if (sizeof($topic_data))
|
||||||
{
|
{
|
||||||
$return_link .= sprintf($user->lang['RETURN_TOPIC'], '<a href="' . append_sid("{$phpbb_root_path}viewtopic.$phpEx", 'f=' . $forum_id . '&t=' . $topic_id) . '">', '</a>');
|
$return_link .= sprintf($user->lang['RETURN_TOPIC'], '<a href="' . append_sid("{$phpbb_root_path}viewtopic.$phpEx", 'f=' . $topic_data['forum_id'] . '&t=' . $topic_id) . '">', '</a>');
|
||||||
}
|
}
|
||||||
|
|
||||||
// Link to the new topic
|
// Link to the new topic
|
||||||
|
|
|
@ -877,11 +877,12 @@ class ucp_groups
|
||||||
}
|
}
|
||||||
|
|
||||||
$name_ary = array_unique(explode("\n", $name_ary));
|
$name_ary = array_unique(explode("\n", $name_ary));
|
||||||
|
$group_name = ($group_row['group_type'] == GROUP_SPECIAL) ? $user->lang['G_' . $group_row['group_name']] : $group_row['group_name'];
|
||||||
|
|
||||||
$default = request_var('default', 0);
|
$default = request_var('default', 0);
|
||||||
|
|
||||||
// Add user/s to group
|
// Add user/s to group
|
||||||
if ($error = group_user_add($group_id, false, $name_ary, $group_row['group_name'], $default, 0, 0, $group_row))
|
if ($error = group_user_add($group_id, false, $name_ary, $group_name, $default, 0, 0, $group_row))
|
||||||
{
|
{
|
||||||
trigger_error($user->lang[$error] . $return_page);
|
trigger_error($user->lang[$error] . $return_page);
|
||||||
}
|
}
|
||||||
|
|
|
@ -45,6 +45,7 @@ $lang = array_merge($lang, array(
|
||||||
'CREATE_FORUM' => 'Create new forum',
|
'CREATE_FORUM' => 'Create new forum',
|
||||||
|
|
||||||
'DECIDE_MOVE_DELETE_CONTENT' => 'Delete content or move to forum',
|
'DECIDE_MOVE_DELETE_CONTENT' => 'Delete content or move to forum',
|
||||||
|
'DECIDE_MOVE_DELETE_SUBFORUMS' => 'Delete subforums or move to forum',
|
||||||
'DEFAULT_STYLE' => 'Default Style',
|
'DEFAULT_STYLE' => 'Default Style',
|
||||||
'DELETE_ALL_POSTS' => 'Delete posts',
|
'DELETE_ALL_POSTS' => 'Delete posts',
|
||||||
'DELETE_SUBFORUMS' => 'Delete subforums and posts',
|
'DELETE_SUBFORUMS' => 'Delete subforums and posts',
|
||||||
|
@ -106,8 +107,8 @@ $lang = array_merge($lang, array(
|
||||||
'LIST_INDEX_EXPLAIN' => 'Displays a link to this forum under the parent forums subforum listing if one exist.',
|
'LIST_INDEX_EXPLAIN' => 'Displays a link to this forum under the parent forums subforum listing if one exist.',
|
||||||
'LOCKED' => 'Locked',
|
'LOCKED' => 'Locked',
|
||||||
|
|
||||||
'MOVE_POSTS_TO' => 'Move posts',
|
'MOVE_POSTS_TO' => 'Move posts to',
|
||||||
'MOVE_SUBFORUMS_TO' => 'Move subforums',
|
'MOVE_SUBFORUMS_TO' => 'Move subforums to',
|
||||||
|
|
||||||
'NO_DESTINATION_FORUM' => 'You have not specified a forum to move content to',
|
'NO_DESTINATION_FORUM' => 'You have not specified a forum to move content to',
|
||||||
'NO_FORUM_ACTION' => 'No action defined for what happens with the forum content',
|
'NO_FORUM_ACTION' => 'No action defined for what happens with the forum content',
|
||||||
|
|
106
phpBB/mcp.php
106
phpBB/mcp.php
|
@ -606,74 +606,74 @@ function mcp_sorting($mode, &$sort_days, &$sort_key, &$sort_dir, &$sort_by_sql,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Validate ids
|
* Validate ids
|
||||||
|
*
|
||||||
|
* @param array &$ids The relevant ids to check
|
||||||
|
* @param string $table The table to find the ids in
|
||||||
|
* @param string $sql_id The ids relevant column name
|
||||||
|
* @param array $acl_list A list of permissions the user need to have
|
||||||
|
* @param mixed $singe_forum Limit to one forum id (int) or the first forum found (true)
|
||||||
|
*
|
||||||
|
* @return mixed False if no ids were able to be retrieved, true if at least one id left.
|
||||||
|
* Additionally, this value can be the forum_id assigned if $single_forum was set.
|
||||||
|
* Therefore checking the result for with !== false is the best method.
|
||||||
*/
|
*/
|
||||||
function check_ids(&$ids, $table, $sql_id, $acl_list = false)
|
function check_ids(&$ids, $table, $sql_id, $acl_list = false, $single_forum = false)
|
||||||
{
|
{
|
||||||
global $db, $auth;
|
global $db, $auth;
|
||||||
|
|
||||||
if (!is_array($ids) || !$ids)
|
if (!is_array($ids) || empty($ids))
|
||||||
{
|
{
|
||||||
return 0;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// a small logical error, since global announcement are assigned to forum_id == 0
|
$sql = "SELECT $sql_id, forum_id FROM $table
|
||||||
// If the first topic id is a global announcement, we can force the forum. Though only global announcements can be
|
WHERE " . $db->sql_in_set($sql_id, $ids);
|
||||||
// tricked... i really do not know how to prevent this atm.
|
|
||||||
|
|
||||||
// With those two queries we make sure all ids are within one forum...
|
|
||||||
$sql = "SELECT forum_id FROM $table
|
|
||||||
WHERE $sql_id = {$ids[0]}";
|
|
||||||
$result = $db->sql_query($sql);
|
|
||||||
$forum_id = (int) $db->sql_fetchfield('forum_id');
|
|
||||||
$db->sql_freeresult($result);
|
|
||||||
|
|
||||||
if (!$forum_id)
|
|
||||||
{
|
|
||||||
// Global Announcement?
|
|
||||||
$forum_id = request_var('f', 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($forum_id === 0)
|
|
||||||
{
|
|
||||||
// Determine first forum the user is able to read - for global announcements
|
|
||||||
$forum_ary = array_unique(array_keys($auth->acl_getf('!f_read', true)));
|
|
||||||
|
|
||||||
$sql = 'SELECT forum_id
|
|
||||||
FROM ' . FORUMS_TABLE . '
|
|
||||||
WHERE forum_type = ' . FORUM_POST;
|
|
||||||
if (sizeof($forum_ary))
|
|
||||||
{
|
|
||||||
$sql .= ' AND ' . $db->sql_in_set('forum_id', $forum_ary, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
$result = $db->sql_query_limit($sql, 1);
|
|
||||||
$forum_id = (int) $db->sql_fetchfield('forum_id');
|
|
||||||
$db->sql_freeresult($result);
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($acl_list && !$auth->acl_gets($acl_list, $forum_id))
|
|
||||||
{
|
|
||||||
trigger_error('NOT_AUTHORIZED');
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!$forum_id)
|
|
||||||
{
|
|
||||||
trigger_error('Missing forum_id, has to be in url if global announcement...', E_USER_ERROR);
|
|
||||||
}
|
|
||||||
|
|
||||||
$sql = "SELECT $sql_id FROM $table
|
|
||||||
WHERE " . $db->sql_in_set($sql_id, $ids) . "
|
|
||||||
AND (forum_id = $forum_id OR forum_id = 0)";
|
|
||||||
$result = $db->sql_query($sql);
|
$result = $db->sql_query($sql);
|
||||||
|
|
||||||
$ids = array();
|
$ids = array();
|
||||||
|
$forum_id = false;
|
||||||
while ($row = $db->sql_fetchrow($result))
|
while ($row = $db->sql_fetchrow($result))
|
||||||
{
|
{
|
||||||
$ids[] = $row[$sql_id];
|
if ($acl_list && $row['forum_id'] && !$auth->acl_gets($acl_list, $row['forum_id']))
|
||||||
|
{
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($acl_list && !$row['forum_id'] && !$auth->acl_getf_global($acl_list))
|
||||||
|
{
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Limit forum? If not, just assign the id.
|
||||||
|
if ($single_forum === false)
|
||||||
|
{
|
||||||
|
$ids[] = $row[$sql_id];
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Limit forum to a specific forum id?
|
||||||
|
if ($single_forum !== true && $row['forum_id'] == (int) $single_forum)
|
||||||
|
{
|
||||||
|
$forum_id = (int) $single_forum;
|
||||||
|
}
|
||||||
|
else if ($forum_id === false)
|
||||||
|
{
|
||||||
|
$forum_id = $row['forum_id'];
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($row['forum_id'] == $forum_id)
|
||||||
|
{
|
||||||
|
$ids[] = $row[$sql_id];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
$db->sql_freeresult($result);
|
$db->sql_freeresult($result);
|
||||||
|
|
||||||
return $forum_id;
|
if (!sizeof($ids))
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return ($single_forum === false) ? true : (int) $forum_id;
|
||||||
}
|
}
|
||||||
|
|
||||||
?>
|
?>
|
|
@ -1117,7 +1117,7 @@ generate_forum_nav($post_data);
|
||||||
// Build Forum Rules
|
// Build Forum Rules
|
||||||
generate_forum_rules($post_data);
|
generate_forum_rules($post_data);
|
||||||
|
|
||||||
if ($config['enable_post_confirm'] && !$user->data['is_registered'] && ($mode == 'post' || $mode == 'reply' || $mode == 'quote'))
|
if ($config['enable_post_confirm'] && !$user->data['is_registered'] && $solved_captcha === false && ($mode == 'post' || $mode == 'reply' || $mode == 'quote'))
|
||||||
{
|
{
|
||||||
// Show confirm image
|
// Show confirm image
|
||||||
$sql = 'DELETE FROM ' . CONFIRM_TABLE . "
|
$sql = 'DELETE FROM ' . CONFIRM_TABLE . "
|
||||||
|
@ -1126,32 +1126,38 @@ if ($config['enable_post_confirm'] && !$user->data['is_registered'] && ($mode ==
|
||||||
$db->sql_query($sql);
|
$db->sql_query($sql);
|
||||||
|
|
||||||
// Generate code
|
// Generate code
|
||||||
if ($solved_captcha === false)
|
$code = gen_rand_string(mt_rand(5, 8));
|
||||||
{
|
$confirm_id = md5(unique_id($user->ip));
|
||||||
$code = gen_rand_string(mt_rand(5, 8));
|
|
||||||
$confirm_id = md5(unique_id($user->ip));
|
|
||||||
|
|
||||||
$sql = 'INSERT INTO ' . CONFIRM_TABLE . ' ' . $db->sql_build_array('INSERT', array(
|
$sql = 'INSERT INTO ' . CONFIRM_TABLE . ' ' . $db->sql_build_array('INSERT', array(
|
||||||
'confirm_id' => (string) $confirm_id,
|
'confirm_id' => (string) $confirm_id,
|
||||||
'session_id' => (string) $user->session_id,
|
'session_id' => (string) $user->session_id,
|
||||||
'confirm_type' => (int) CONFIRM_POST,
|
'confirm_type' => (int) CONFIRM_POST,
|
||||||
'code' => (string) $code)
|
'code' => (string) $code)
|
||||||
);
|
);
|
||||||
$db->sql_query($sql);
|
$db->sql_query($sql);
|
||||||
|
|
||||||
$template->assign_vars(array(
|
$template->assign_vars(array(
|
||||||
'S_CONFIRM_CODE' => true,
|
'S_CONFIRM_CODE' => true,
|
||||||
'CONFIRM_ID' => $confirm_id,
|
'CONFIRM_ID' => $confirm_id,
|
||||||
'CONFIRM_IMAGE' => '<img src="' . append_sid("{$phpbb_root_path}ucp.$phpEx", 'mode=confirm&id=' . $confirm_id . '&type=' . CONFIRM_POST) . '" alt="" title="" />',
|
'CONFIRM_IMAGE' => '<img src="' . append_sid("{$phpbb_root_path}ucp.$phpEx", 'mode=confirm&id=' . $confirm_id . '&type=' . CONFIRM_POST) . '" alt="" title="" />',
|
||||||
'L_POST_CONFIRM_EXPLAIN' => sprintf($user->lang['POST_CONFIRM_EXPLAIN'], '<a href="mailto:' . htmlspecialchars($config['board_contact']) . '">', '</a>'),
|
'L_POST_CONFIRM_EXPLAIN' => sprintf($user->lang['POST_CONFIRM_EXPLAIN'], '<a href="mailto:' . htmlspecialchars($config['board_contact']) . '">', '</a>'),
|
||||||
));
|
));
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$s_hidden_fields = ($mode == 'reply' || $mode == 'quote') ? '<input type="hidden" name="topic_cur_post_id" value="' . $post_data['topic_last_post_id'] . '" />' : '';
|
$s_hidden_fields = ($mode == 'reply' || $mode == 'quote') ? '<input type="hidden" name="topic_cur_post_id" value="' . $post_data['topic_last_post_id'] . '" />' : '';
|
||||||
$s_hidden_fields .= '<input type="hidden" name="lastclick" value="' . $current_time . '" />';
|
$s_hidden_fields .= '<input type="hidden" name="lastclick" value="' . $current_time . '" />';
|
||||||
$s_hidden_fields .= ($draft_id || isset($_REQUEST['draft_loaded'])) ? '<input type="hidden" name="draft_loaded" value="' . request_var('draft_loaded', $draft_id) . '" />' : '';
|
$s_hidden_fields .= ($draft_id || isset($_REQUEST['draft_loaded'])) ? '<input type="hidden" name="draft_loaded" value="' . request_var('draft_loaded', $draft_id) . '" />' : '';
|
||||||
|
|
||||||
|
// Add the confirm id/code pair to the hidden fields, else an error is displayed on next submit/preview
|
||||||
|
if ($solved_captcha !== false)
|
||||||
|
{
|
||||||
|
$s_hidden_fields .= build_hidden_fields(array(
|
||||||
|
'confirm_id' => request_var('confirm_id', ''),
|
||||||
|
'confirm_code' => request_var('confirm_code', ''))
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
$form_enctype = (@ini_get('file_uploads') == '0' || strtolower(@ini_get('file_uploads')) == 'off' || @ini_get('file_uploads') == '0' || !$config['allow_attachments'] || !$auth->acl_get('u_attach') || !$auth->acl_get('f_attach', $forum_id)) ? '' : ' enctype="multipart/form-data"';
|
$form_enctype = (@ini_get('file_uploads') == '0' || strtolower(@ini_get('file_uploads')) == 'off' || @ini_get('file_uploads') == '0' || !$config['allow_attachments'] || !$auth->acl_get('u_attach') || !$auth->acl_get('f_attach', $forum_id)) ? '' : ' enctype="multipart/form-data"';
|
||||||
|
|
||||||
// Start assigning vars for main posting page ...
|
// Start assigning vars for main posting page ...
|
||||||
|
@ -1178,7 +1184,7 @@ $template->assign_vars(array(
|
||||||
'TOPIC_TIME_LIMIT' => (int) $post_data['topic_time_limit'],
|
'TOPIC_TIME_LIMIT' => (int) $post_data['topic_time_limit'],
|
||||||
'EDIT_REASON' => $post_data['post_edit_reason'],
|
'EDIT_REASON' => $post_data['post_edit_reason'],
|
||||||
'U_VIEW_FORUM' => append_sid("{$phpbb_root_path}viewforum.$phpEx", "f=$forum_id"),
|
'U_VIEW_FORUM' => append_sid("{$phpbb_root_path}viewforum.$phpEx", "f=$forum_id"),
|
||||||
'U_VIEWTOPIC' => ($mode != 'post') ? append_sid("{$phpbb_root_path}viewtopic.$phpEx", "f=$forum_id&t=$topic_id") : '',
|
'U_VIEW_TOPIC' => ($mode != 'post') ? append_sid("{$phpbb_root_path}viewtopic.$phpEx", "f=$forum_id&t=$topic_id") : '',
|
||||||
'U_PROGRESS_BAR' => append_sid("{$phpbb_root_path}posting.$phpEx", "f=$forum_id&mode=popup"),
|
'U_PROGRESS_BAR' => append_sid("{$phpbb_root_path}posting.$phpEx", "f=$forum_id&mode=popup"),
|
||||||
'UA_PROGRESS_BAR' => append_sid("{$phpbb_root_path}posting.$phpEx", "f=$forum_id&mode=popup", false),
|
'UA_PROGRESS_BAR' => append_sid("{$phpbb_root_path}posting.$phpEx", "f=$forum_id&mode=popup", false),
|
||||||
|
|
||||||
|
|
|
@ -10,7 +10,7 @@
|
||||||
|
|
||||||
<table class="tablebg" width="100%" cellspacing="1">
|
<table class="tablebg" width="100%" cellspacing="1">
|
||||||
<tr>
|
<tr>
|
||||||
<td class="cat" colspan="6" align="center"><span class="gensmall">{L_DISPLAY_TOPICS}:</span> {S_SELECT_SORT_DAYS} <span class="gensmall">{L_SORT_BY}</span> {S_SELECT_SORT_KEY} {S_SELECT_SORT_DIR} <input class="btnlite" type="submit" name="sort" value="{L_GO}" /></span></td>
|
<td class="cat" colspan="6" align="center"><span class="gensmall">{L_DISPLAY_TOPICS}:</span> {S_SELECT_SORT_DAYS} <span class="gensmall">{L_SORT_BY}</span> {S_SELECT_SORT_KEY} {S_SELECT_SORT_DIR} <input class="btnlite" type="submit" name="sort" value="{L_GO}" /></td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<th width="4%" nowrap="nowrap"> </th>
|
<th width="4%" nowrap="nowrap"> </th>
|
||||||
|
@ -50,7 +50,7 @@
|
||||||
<tr>
|
<tr>
|
||||||
<td class="cat" colspan="6" align="right">
|
<td class="cat" colspan="6" align="right">
|
||||||
<select name="action">
|
<select name="action">
|
||||||
<option value="" checked="checked">{L_SELECT_ACTION}</option>
|
<option value="" selected="selected">{L_SELECT_ACTION}</option>
|
||||||
<!-- IF S_CAN_DELETE --><option value="delete_topic">{L_DELETE}</option><!-- ENDIF -->
|
<!-- IF S_CAN_DELETE --><option value="delete_topic">{L_DELETE}</option><!-- ENDIF -->
|
||||||
<!-- IF S_CAN_MOVE --><option value="move">{L_MOVE}</option><!-- ENDIF -->
|
<!-- IF S_CAN_MOVE --><option value="move">{L_MOVE}</option><!-- ENDIF -->
|
||||||
<!-- IF S_CAN_FORK --><option value="fork">{L_FORK}</option><!-- ENDIF -->
|
<!-- IF S_CAN_FORK --><option value="fork">{L_FORK}</option><!-- ENDIF -->
|
||||||
|
|
|
@ -87,7 +87,7 @@
|
||||||
<td class="row1" nowrap="nowrap"><span class="gen">{log.USERNAME}</span></td>
|
<td class="row1" nowrap="nowrap"><span class="gen">{log.USERNAME}</span></td>
|
||||||
<td class="row1" align="center" nowrap="nowrap"><span class="gen">{log.IP}</span></td>
|
<td class="row1" align="center" nowrap="nowrap"><span class="gen">{log.IP}</span></td>
|
||||||
<td class="row1"><span class="genmed">{log.ACTION}</span></td>
|
<td class="row1"><span class="genmed">{log.ACTION}</span></td>
|
||||||
<td class="row1" align="center" nowrap="nowrap"><span class="gensmall"><!-- IF log.U_VIEWTOPIC --><a href="{log.U_VIEWTOPIC}">{L_VIEW_TOPIC}</a><!-- IF log.U_VIEWLOGS --> | <!-- ENDIF --><!-- ENDIF --><!-- IF log.U_VIEWLOGS --><a href="{log.U_VIEWLOGS}">{L_VIEW_TOPIC_LOGS}</a><!-- ENDIF --></span></td>
|
<td class="row1" align="center" nowrap="nowrap"><span class="gensmall"><!-- IF log.U_VIEW_TOPIC --><a href="{log.U_VIEW_TOPIC}">{L_VIEW_TOPIC}</a><!-- IF log.U_VIEWLOGS --> | <!-- ENDIF --><!-- ENDIF --><!-- IF log.U_VIEWLOGS --><a href="{log.U_VIEWLOGS}">{L_VIEW_TOPIC_LOGS}</a><!-- ENDIF --></span></td>
|
||||||
<td class="row1" align="center" nowrap="nowrap"><span class="gensmall">{log.TIME}</span></td>
|
<td class="row1" align="center" nowrap="nowrap"><span class="gensmall">{log.TIME}</span></td>
|
||||||
</tr>
|
</tr>
|
||||||
<!-- BEGINELSE -->
|
<!-- BEGINELSE -->
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
|
|
||||||
<!-- IF TOPIC_TITLE or FORUM_NAME -->
|
<!-- IF TOPIC_TITLE or FORUM_NAME -->
|
||||||
<div id="pageheader">
|
<div id="pageheader">
|
||||||
<h2><!-- IF TOPIC_TITLE --><a class="titles" href="{U_VIEWTOPIC}">{TOPIC_TITLE}</a><!-- ELSE --><a class="titles" href="{U_VIEW_FORUM}">{FORUM_NAME}</a><!-- ENDIF --></h2>
|
<h2><!-- IF TOPIC_TITLE --><a class="titles" href="{U_VIEW_TOPIC}">{TOPIC_TITLE}</a><!-- ELSE --><a class="titles" href="{U_VIEW_FORUM}">{FORUM_NAME}</a><!-- ENDIF --></h2>
|
||||||
|
|
||||||
<!-- IF MODERATORS -->
|
<!-- IF MODERATORS -->
|
||||||
<p class="moderators">{L_MODERATORS}: {MODERATORS}</p>
|
<p class="moderators">{L_MODERATORS}: {MODERATORS}</p>
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
|
|
||||||
<form method="post" name="mcp" action="{U_POST_ACTION}">
|
<form method="post" name="mcp" action="{U_POST_ACTION}">
|
||||||
|
|
||||||
<table class="bg" width="75%" cellspacing="1" cellpadding="4" border="0" align="center">
|
<table class="bg" width="100%" cellspacing="1" cellpadding="4" border="0" align="center">
|
||||||
<tr>
|
<tr>
|
||||||
<th colspan="2"align="center">{L_SELECT_USER}</th>
|
<th colspan="2"align="center">{L_SELECT_USER}</th>
|
||||||
</tr>
|
</tr>
|
||||||
|
|
|
@ -38,7 +38,7 @@
|
||||||
<br clear="all"/>
|
<br clear="all"/>
|
||||||
<!-- ENDIF -->
|
<!-- ENDIF -->
|
||||||
|
|
||||||
<!-- IF S_MCP_QUEUE --><form method="post" name="mcp_approve" action="{U_APPROVE_ACTION}"><!-- ELSE --><form method="post" name="mcp_report" action="{U_CLOSE_ACTION}"><!-- ENDIF -->
|
<!-- IF S_MCP_QUEUE --><form method="post" name="mcp_approve" action="{U_APPROVE_ACTION}"><!-- ELSE --><form method="post" name="mcp_report_details" action="{U_CLOSE_ACTION}"><!-- ENDIF -->
|
||||||
|
|
||||||
<table width="100%" cellpadding="3" cellspacing="1" border="0" class="tablebg">
|
<table width="100%" cellpadding="3" cellspacing="1" border="0" class="tablebg">
|
||||||
<tr>
|
<tr>
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
<th colspan="6" nowrap="nowrap">{L_DISPLAY_OPTIONS}</th>
|
<th colspan="6" nowrap="nowrap">{L_DISPLAY_OPTIONS}</th>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td colspan="5" class="cat" align="center"><span class="gensmall">{L_DISPLAY_ITEMS}:</span> {S_SELECT_SORT_DAYS} <span class="gensmall">{L_SORT_BY}</span> {S_SELECT_SORT_KEY} {S_SELECT_SORT_DIR} <span class="gensmall">{L_FORUM}</span> <select name="f">{S_FORUM_OPTIONS}</select> <!-- IF TOPIC_ID --><input type="checkbox" class="radio" name="t" value="{TOPIC_ID}" checked="checked" /> <b>{L_ONLY_TOPIC}</b> <!-- ENDIF --><input class="btnlite" type="submit" name="sort" value="{L_GO}" /></span></td>
|
<td colspan="5" class="cat" align="center"><span class="gensmall">{L_DISPLAY_ITEMS}:</span> {S_SELECT_SORT_DAYS} <span class="gensmall">{L_SORT_BY}</span> {S_SELECT_SORT_KEY} {S_SELECT_SORT_DIR} <span class="gensmall">{L_FORUM}</span> <select name="f">{S_FORUM_OPTIONS}</select> <!-- IF TOPIC_ID --><input type="checkbox" class="radio" name="t" value="{TOPIC_ID}" checked="checked" /> <b>{L_ONLY_TOPIC}</b> <!-- ENDIF --><input class="btnlite" type="submit" name="sort" value="{L_GO}" /></td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<th> <!-- IF S_TOPICS -->{L_TOPIC}<!-- ELSE -->{L_POST}<!-- ENDIF --> </th>
|
<th> <!-- IF S_TOPICS -->{L_TOPIC}<!-- ELSE -->{L_POST}<!-- ENDIF --> </th>
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
<th colspan="5" nowrap="nowrap">{L_DISPLAY_OPTIONS}</th>
|
<th colspan="5" nowrap="nowrap">{L_DISPLAY_OPTIONS}</th>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td colspan="5" class="cat" align="center"><span class="gensmall">{L_DISPLAY_POSTS}:</span> {S_SELECT_SORT_DAYS} <span class="gensmall">{L_SORT_BY}</span> {S_SELECT_SORT_KEY} {S_SELECT_SORT_DIR} <span class="gensmall">{L_FORUM}</span> <select name="f">{S_FORUM_OPTIONS}</select> <!-- IF TOPIC_ID --><input type="checkbox" class="radio" name="t" value="{TOPIC_ID}" checked="checked" /> <b>{L_ONLY_TOPIC}</b> <!-- ENDIF --><input class="btnlite" type="submit" name="sort" value="{L_GO}" /></span></td>
|
<td colspan="5" class="cat" align="center"><span class="gensmall">{L_DISPLAY_POSTS}:</span> {S_SELECT_SORT_DAYS} <span class="gensmall">{L_SORT_BY}</span> {S_SELECT_SORT_KEY} {S_SELECT_SORT_DIR} <span class="gensmall">{L_FORUM}</span> <select name="f">{S_FORUM_OPTIONS}</select> <!-- IF TOPIC_ID --><input type="checkbox" class="radio" name="t" value="{TOPIC_ID}" checked="checked" /> <b>{L_ONLY_TOPIC}</b> <!-- ENDIF --><input class="btnlite" type="submit" name="sort" value="{L_GO}" /></td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<th> {L_POST} </th>
|
<th> {L_POST} </th>
|
||||||
|
@ -23,7 +23,7 @@
|
||||||
<span class="gensmall"><!-- IF postrow.U_VIEWFORUM -->{L_FORUM}: <a href="{postrow.U_VIEWFORUM}">{postrow.FORUM_NAME}</a><!-- ELSE -->{postrow.FORUM_NAME}<!-- ENDIF --></span></td>
|
<span class="gensmall"><!-- IF postrow.U_VIEWFORUM -->{L_FORUM}: <a href="{postrow.U_VIEWFORUM}">{postrow.FORUM_NAME}</a><!-- ELSE -->{postrow.FORUM_NAME}<!-- ENDIF --></span></td>
|
||||||
<td style="padding: 4px;" align="left" valign="top" nowrap="nowrap"><span class="gen">{postrow.POST_AUTHOR_FULL}</span><br />
|
<td style="padding: 4px;" align="left" valign="top" nowrap="nowrap"><span class="gen">{postrow.POST_AUTHOR_FULL}</span><br />
|
||||||
<span class="gensmall">{postrow.POST_TIME}</span></td>
|
<span class="gensmall">{postrow.POST_TIME}</span></td>
|
||||||
<td style="padding: 4px;" align="left" valign="top" nowrap="nowrap"><span class="gen"><!-- IF postrow.U_VIEW_REPORTER_PROFILE --><a href="{postrow.U_VIEW_REPORTER_PROFILE}">{postrow.REPORTER}</a><!-- ELSE -->{postrow.REPORTER}<!-- ENDIF --></span></td>
|
<td style="padding: 4px;" align="left" valign="top" nowrap="nowrap"><span class="gen">{postrow.REPORTER_FULL}</span></td>
|
||||||
<td style="padding: 4px;" align="left" valign="top" nowrap="nowrap"><span class="gen">{postrow.REPORT_TIME}</span><br />
|
<td style="padding: 4px;" align="left" valign="top" nowrap="nowrap"><span class="gen">{postrow.REPORT_TIME}</span><br />
|
||||||
<span class="gensmall">[ <a href="{postrow.U_VIEW_DETAILS}">{L_VIEW_DETAILS}</a> ]</span></td>
|
<span class="gensmall">[ <a href="{postrow.U_VIEW_DETAILS}">{L_VIEW_DETAILS}</a> ]</span></td>
|
||||||
<td align="center"><input type="checkbox" class="radio" name="post_id_list[]" value="{postrow.POST_ID}" /></td>
|
<td align="center"><input type="checkbox" class="radio" name="post_id_list[]" value="{postrow.POST_ID}" /></td>
|
||||||
|
|
|
@ -12,7 +12,7 @@
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td class="row1" nowrap="nowrap"><span class="gen">{L_SPLIT_SUBJECT}</span></td>
|
<td class="row1" nowrap="nowrap"><span class="gen">{L_SPLIT_SUBJECT}</span></td>
|
||||||
<td class="row2" colspan="2"><input class="post" style="width: 350px" type="text" size="35" maxlength="100" name="subject" value="{SPLIT_SUBJECT}" /></span></td>
|
<td class="row2" colspan="2"><input class="post" style="width: 350px" type="text" size="35" maxlength="100" name="subject" value="{SPLIT_SUBJECT}" /></td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td class="row1" nowrap="nowrap"><span class="gen">{L_SPLIT_FORUM}</span></td>
|
<td class="row1" nowrap="nowrap"><span class="gen">{L_SPLIT_FORUM}</span></td>
|
||||||
|
@ -55,10 +55,10 @@
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td class="row1" nowrap="nowrap"><span class="gen">{L_POSTS_PER_PAGE}</span><br /><span class="gensmall">{L_POSTS_PER_PAGE_EXPLAIN}</span</td>
|
<td class="row1" nowrap="nowrap"><span class="gen">{L_POSTS_PER_PAGE}</span><br /><span class="gensmall">{L_POSTS_PER_PAGE_EXPLAIN}</span</td>
|
||||||
<td class="row2" colspan="2"><input class="post" type="text" name="posts_per_page" size="6" value="{POSTS_PER_PAGE}"></td>
|
<td class="row2" colspan="2"><input class="post" type="text" name="posts_per_page" size="6" value="{POSTS_PER_PAGE}" /></td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td class="cat" colspan="3" align="center"><span class="gensmall">{L_DISPLAY_POSTS}:</span> {S_SELECT_SORT_DAYS} <span class="gensmall">{L_SORT_BY}</span> {S_SELECT_SORT_KEY} {S_SELECT_SORT_DIR} <input class="btnlite" type="submit" name="sort" value="{L_GO}" /></span></td>
|
<td class="cat" colspan="3" align="center"><span class="gensmall">{L_DISPLAY_POSTS}:</span> {S_SELECT_SORT_DAYS} <span class="gensmall">{L_SORT_BY}</span> {S_SELECT_SORT_KEY} {S_SELECT_SORT_DIR} <input class="btnlite" type="submit" name="sort" value="{L_GO}" /></td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<th nowrap="nowrap">{L_AUTHOR}</th>
|
<th nowrap="nowrap">{L_AUTHOR}</th>
|
||||||
|
@ -126,9 +126,10 @@
|
||||||
<!-- IF S_CAN_DELETE --><option value="delete_post">{L_DELETE_POSTS}</option><!-- ENDIF -->
|
<!-- IF S_CAN_DELETE --><option value="delete_post">{L_DELETE_POSTS}</option><!-- ENDIF -->
|
||||||
<!-- IF S_CAN_MERGE --><option value="merge_posts"<!-- IF ACTION eq 'merge' --> selected="selected"<!-- ENDIF -->>{L_MERGE_POSTS}</option><!-- ENDIF -->
|
<!-- IF S_CAN_MERGE --><option value="merge_posts"<!-- IF ACTION eq 'merge' --> selected="selected"<!-- ENDIF -->>{L_MERGE_POSTS}</option><!-- ENDIF -->
|
||||||
<!-- IF S_CAN_SPLIT --><option value="split_all"<!-- IF ACTION eq 'split' --> selected="selected"<!-- ENDIF -->>{L_SPLIT_POSTS}</option><option value="split_beyond">{L_SPLIT_AFTER}</option><!-- ENDIF -->
|
<!-- IF S_CAN_SPLIT --><option value="split_all"<!-- IF ACTION eq 'split' --> selected="selected"<!-- ENDIF -->>{L_SPLIT_POSTS}</option><option value="split_beyond">{L_SPLIT_AFTER}</option><!-- ENDIF -->
|
||||||
</select> <input class="btnmain" type="submit" name="mcp_topic_submit" value="{L_SUBMIT}"></form></td>
|
</select> <input class="btnmain" type="submit" name="mcp_topic_submit" value="{L_SUBMIT}" /></td>
|
||||||
</tr>
|
</tr>
|
||||||
</table>
|
</table>
|
||||||
|
|
||||||
</form>
|
</form>
|
||||||
|
|
||||||
<table width="100%" cellspacing="2" cellpadding="2" border="0" align="center">
|
<table width="100%" cellspacing="2" cellpadding="2" border="0" align="center">
|
||||||
|
|
|
@ -20,7 +20,7 @@
|
||||||
</tr>
|
</tr>
|
||||||
<!-- IF S_TOPIC_ID -->
|
<!-- IF S_TOPIC_ID -->
|
||||||
<tr>
|
<tr>
|
||||||
<td class="row3" colspan="5"><span class="gensmall">{L_LOGS_CURRENT_TOPIC} <a href="{U_VIEWTOPIC}"><b>{TOPIC_NAME}</b></a></span></td>
|
<td class="row3" colspan="5"><span class="gensmall">{L_LOGS_CURRENT_TOPIC} <a href="{U_VIEW_TOPIC}"><b>{TOPIC_NAME}</b></a></span></td>
|
||||||
</tr>
|
</tr>
|
||||||
<!-- ENDIF -->
|
<!-- ENDIF -->
|
||||||
<!-- BEGIN log -->
|
<!-- BEGIN log -->
|
||||||
|
@ -30,7 +30,7 @@
|
||||||
<td class="row1" align="center" nowrap="nowrap"><span class="gensmall">{log.TIME}</span></td>
|
<td class="row1" align="center" nowrap="nowrap"><span class="gensmall">{log.TIME}</span></td>
|
||||||
<td class="row1"><span class="gen">{log.ACTION}</span></td>
|
<td class="row1"><span class="gen">{log.ACTION}</span></td>
|
||||||
<!-- IF not S_TOPIC_ID -->
|
<!-- IF not S_TOPIC_ID -->
|
||||||
<td class="row1" align="center" nowrap="nowrap"><span class="gensmall"><!-- IF log.U_VIEWTOPIC --><a href="{log.U_VIEWTOPIC}">{L_VIEW_TOPIC}</a><!-- IF log.U_VIEWLOGS --> | <!-- ENDIF --><!-- ENDIF --><!-- IF log.U_VIEWLOGS --><a href="{log.U_VIEWLOGS}">{L_VIEW_TOPIC_LOGS}</a><!-- ENDIF --></span></td>
|
<td class="row1" align="center" nowrap="nowrap"><span class="gensmall"><!-- IF log.U_VIEW_TOPIC --><a href="{log.U_VIEW_TOPIC}">{L_VIEW_TOPIC}</a><!-- IF log.U_VIEWLOGS --> | <!-- ENDIF --><!-- ENDIF --><!-- IF log.U_VIEWLOGS --><a href="{log.U_VIEWLOGS}">{L_VIEW_TOPIC_LOGS}</a><!-- ENDIF --></span></td>
|
||||||
<!-- ENDIF -->
|
<!-- ENDIF -->
|
||||||
</tr>
|
</tr>
|
||||||
<!-- BEGINELSE -->
|
<!-- BEGINELSE -->
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
|
|
||||||
<form method="post" name="mcp" action="{U_POST_ACTION}">
|
<form method="post" name="mcp" action="{U_POST_ACTION}">
|
||||||
|
|
||||||
<table class="bg" width="75%" cellspacing="1" cellpadding="4" border="0" align="center">
|
<table class="bg" width="100%" cellspacing="1" border="0" align="center">
|
||||||
<tr>
|
<tr>
|
||||||
<th colspan="2"align="center">{L_SELECT_USER}</th>
|
<th colspan="2"align="center">{L_SELECT_USER}</th>
|
||||||
</tr>
|
</tr>
|
||||||
|
|
|
@ -70,7 +70,7 @@ function checkForm()
|
||||||
|
|
||||||
<!-- IF not S_PRIVMSGS -->
|
<!-- IF not S_PRIVMSGS -->
|
||||||
<div id="pageheader">
|
<div id="pageheader">
|
||||||
<h2><!-- IF TOPIC_TITLE --><a class="titles" href="{U_VIEWTOPIC}">{TOPIC_TITLE}</a><!-- ELSE --><a class="titles" href="{U_VIEW_FORUM}">{FORUM_NAME}</a><!-- ENDIF --></h2>
|
<h2><!-- IF TOPIC_TITLE --><a class="titles" href="{U_VIEW_TOPIC}">{TOPIC_TITLE}</a><!-- ELSE --><a class="titles" href="{U_VIEW_FORUM}">{FORUM_NAME}</a><!-- ENDIF --></h2>
|
||||||
|
|
||||||
<!-- IF MODERATORS -->
|
<!-- IF MODERATORS -->
|
||||||
<p class="moderators">{L_MODERATORS}: {MODERATORS}</p>
|
<p class="moderators">{L_MODERATORS}: {MODERATORS}</p>
|
||||||
|
|
|
@ -1434,7 +1434,7 @@ for ($i = 0, $end = sizeof($post_list); $i < $end; ++$i)
|
||||||
'U_NEXT_POST_ID' => ($i < $i_total && isset($rowset[$post_list[$i + 1]])) ? $rowset[$post_list[$i + 1]]['post_id'] : '',
|
'U_NEXT_POST_ID' => ($i < $i_total && isset($rowset[$post_list[$i + 1]])) ? $rowset[$post_list[$i + 1]]['post_id'] : '',
|
||||||
'U_PREV_POST_ID' => $prev_post_id,
|
'U_PREV_POST_ID' => $prev_post_id,
|
||||||
'U_NOTES' => ($auth->acl_getf_global('m_')) ? append_sid("{$phpbb_root_path}mcp.$phpEx", 'i=notes&mode=user_notes&u=' . $poster_id, true, $user->session_id) : '',
|
'U_NOTES' => ($auth->acl_getf_global('m_')) ? append_sid("{$phpbb_root_path}mcp.$phpEx", 'i=notes&mode=user_notes&u=' . $poster_id, true, $user->session_id) : '',
|
||||||
'U_WARN' => ($auth->acl_getf_global('m_warn') && $poster_id != $user->data['user_id']) ? append_sid("{$phpbb_root_path}mcp.$phpEx", 'i=warn&mode=warn_post&f=' . $forum_id . '&p=' . $row['post_id'], true, $user->session_id) : '',
|
'U_WARN' => ($auth->acl_getf_global('m_warn') && $poster_id != $user->data['user_id'] && $poster_id != ANONYMOUS) ? append_sid("{$phpbb_root_path}mcp.$phpEx", 'i=warn&mode=warn_post&f=' . $forum_id . '&p=' . $row['post_id'], true, $user->session_id) : '',
|
||||||
|
|
||||||
'POST_ID' => $row['post_id'],
|
'POST_ID' => $row['post_id'],
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue