Zeile 3 | Zeile 3 |
---|
* MyBB 1.2 * Copyright � 2006 MyBB Group, All Rights Reserved *
|
* MyBB 1.2 * Copyright � 2006 MyBB Group, All Rights Reserved *
|
* Website: http://www.mybboard.com * License: http://www.mybboard.com/eula.html
| * Website: http://www.mybboard.net * License: http://www.mybboard.net/eula.html
|
*
|
*
|
* $Id: class_moderation.php 2063 2006-08-12 08:12:26Z chris $
| * $Id: class_moderation.php 3171 2007-06-29 04:57:39Z chris $
|
*/
class Moderation
| */
class Moderation
|
Zeile 19 | Zeile 19 |
---|
*/ function close_threads($tids) {
|
*/ function close_threads($tids) {
|
global $db;
| global $db, $plugins;
|
if(!is_array($tids)) { $tids = array($tids); } $tid_list = implode(",", $tids);
|
if(!is_array($tids)) { $tids = array($tids); } $tid_list = implode(",", $tids);
|
| $plugins->run_hooks("class_moderation_close_threads", $tids);
|
$openthread = array( "closed" => "yes", ); $db->update_query(TABLE_PREFIX."threads", $openthread, "tid IN ($tid_list)");
|
$openthread = array( "closed" => "yes", ); $db->update_query(TABLE_PREFIX."threads", $openthread, "tid IN ($tid_list)");
|
|
|
return true; }
| return true; }
|
Zeile 43 | Zeile 45 |
---|
*/
function open_threads($tids)
|
*/
function open_threads($tids)
|
{ global $db;
| { global $db, $plugins;
|
if(!is_array($tids)) { $tids = array($tids); } $tid_list = implode(",", $tids);
|
if(!is_array($tids)) { $tids = array($tids); } $tid_list = implode(",", $tids);
|
| $plugins->run_hooks("class_moderation_open_threads", $tids);
|
$closethread = array( "closed" => "no",
|
$closethread = array( "closed" => "no",
|
); $db->update_query(TABLE_PREFIX."threads", $closethread, "tid IN ($tid_list)");
| ); $db->update_query(TABLE_PREFIX."threads", $closethread, "tid IN ($tid_list)");
|
return true; }
| return true; }
|
Zeile 67 | Zeile 71 |
---|
* @return boolean true */ function stick_threads($tids)
|
* @return boolean true */ function stick_threads($tids)
|
{ global $db;
| { global $db, $plugins;
|
if(!is_array($tids)) { $tids = array($tids); } $tid_list = implode(",", $tids);
|
if(!is_array($tids)) { $tids = array($tids); } $tid_list = implode(",", $tids);
|
| $plugins->run_hooks("class_moderation_stick_threads", $tids);
|
$stickthread = array( "sticky" => 1,
|
$stickthread = array( "sticky" => 1,
|
); $db->update_query(TABLE_PREFIX."threads", $stickthread, "tid IN ($tid_list)");
return true;
| ); $db->update_query(TABLE_PREFIX."threads", $stickthread, "tid IN ($tid_list)");
return true;
|
}
/**
| }
/**
|
Zeile 92 | Zeile 98 |
---|
*/ function unstick_threads($tids) {
|
*/ function unstick_threads($tids) {
|
global $db;
| global $db, $plugins;
|
if(!is_array($tids)) { $tids = array($tids); } $tid_list = implode(",", $tids);
|
if(!is_array($tids)) { $tids = array($tids); } $tid_list = implode(",", $tids);
|
| $plugins->run_hooks("class_moderation_unstick_threads", $tids);
|
$unstickthread = array( "sticky" => 0,
| $unstickthread = array( "sticky" => 0,
|
Zeile 116 | Zeile 124 |
---|
*/ function remove_redirects($tid) {
|
*/ function remove_redirects($tid) {
|
global $db;
| global $db, $plugins;
$plugins->run_hooks("class_moderation_remove_redirects", $tid);
|
|
|
// Find the fids that have these redirects $query = $db->simple_select(TABLE_PREFIX."threads", "fid", "closed='moved|$tid'"); while($forum = $db->fetch_array($query)) { $fids[] = $forum['fid']; }
| |
// Delete the redirects
|
// Delete the redirects
|
$db->delete_query(TABLE_PREFIX."threads", "closed='moved|$tid'"); // Update the forum stats of the fids found above if(is_array($fids)) { foreach($fids as $fid) { update_forum_count($fid); } }
return true;
| $db->delete_query(TABLE_PREFIX."threads", "closed='moved|$tid'"); return true;
|
}
/**
| }
/**
|
Zeile 147 | Zeile 142 |
---|
function delete_thread($tid) { global $db, $cache, $plugins;
|
function delete_thread($tid) { global $db, $cache, $plugins;
|
| $thread = get_thread($tid);
|
// Find the pid, uid, visibility, and forum post count status $query = $db->query("
| // Find the pid, uid, visibility, and forum post count status $query = $db->query("
|
Zeile 155 | Zeile 152 |
---|
LEFT JOIN ".TABLE_PREFIX."forums f ON (f.fid=p.fid) WHERE p.tid='$tid' ");
|
LEFT JOIN ".TABLE_PREFIX."forums f ON (f.fid=p.fid) WHERE p.tid='$tid' ");
|
$num_unapproved_posts = 0;
| $pids = array(); $num_unapproved_posts = $num_approved_posts = 0;
|
while($post = $db->fetch_array($query)) {
|
while($post = $db->fetch_array($query)) {
|
// Count the post counts for each user to be subtracted if($userposts[$post['uid']]) { $userposts[$post['uid']]--; } else { $userposts[$post['uid']] = -1; } $pids .= $post['pid'].",";
| $pids[] = $post['pid'];
|
$usepostcounts = $post['usepostcounts'];
|
$usepostcounts = $post['usepostcounts'];
|
|
|
// Remove attachments remove_attachments($post['pid']);
|
// Remove attachments remove_attachments($post['pid']);
|
|
|
// If the post is unapproved, count it! if($post['visible'] == 0)
|
// If the post is unapproved, count it! if($post['visible'] == 0)
|
{
| {
|
$num_unapproved_posts++;
|
$num_unapproved_posts++;
|
}
| continue; } else { $num_approved_posts++; // Count the post counts for each user to be subtracted if($userposts[$post['uid']]) { $userposts[$post['uid']]--; } else { $userposts[$post['uid']] = -1; } }
|
} // Remove post count from users if($usepostcounts != "no")
| } // Remove post count from users if($usepostcounts != "no")
|
Zeile 192 | Zeile 196 |
---|
// Delete posts and their attachments if($pids) {
|
// Delete posts and their attachments if($pids) {
|
$pids .= "0";
| $pids = implode(",", $pids);
|
$db->delete_query(TABLE_PREFIX."posts", "pid IN ($pids)"); $db->delete_query(TABLE_PREFIX."attachments", "pid IN ($pids)"); } // Get thread info $query = $db->simple_select(TABLE_PREFIX."threads", "*", "tid='$tid'"); $thread = $db->fetch_array($query);
|
$db->delete_query(TABLE_PREFIX."posts", "pid IN ($pids)"); $db->delete_query(TABLE_PREFIX."attachments", "pid IN ($pids)"); } // Get thread info $query = $db->simple_select(TABLE_PREFIX."threads", "*", "tid='$tid'"); $thread = $db->fetch_array($query);
|
| // Implied counters for unapproved thread if($thread['visible'] == 0) { $num_unapproved_posts += $thread['replies']; }
|
// Delete threads, redirects, favorites, polls, and poll votes $db->delete_query(TABLE_PREFIX."threads", "tid='$tid'");
| // Delete threads, redirects, favorites, polls, and poll votes $db->delete_query(TABLE_PREFIX."threads", "tid='$tid'");
|
Zeile 206 | Zeile 216 |
---|
$db->delete_query(TABLE_PREFIX."favorites", "tid='$tid'"); $db->delete_query(TABLE_PREFIX."polls", "tid='$tid'"); $db->delete_query(TABLE_PREFIX."pollvotes", "pid='".$thread['poll']."'");
|
$db->delete_query(TABLE_PREFIX."favorites", "tid='$tid'"); $db->delete_query(TABLE_PREFIX."polls", "tid='$tid'"); $db->delete_query(TABLE_PREFIX."pollvotes", "pid='".$thread['poll']."'");
|
$cache->updatestats(); update_forum_count($thread['fid']); $plugins->run_hooks("delete_thread", $tid);
| $updated_counters = array( "posts" => "-{$num_approved_posts}", "unapprovedposts" => "-{$num_unapproved_posts}" ); if($thread['visible'] == 1) { $updated_counters['threads'] = -1; } else { $updated_counters['unapprovedthreads'] = -1; } if(substr($thread['closed'], 0, 5) != "moved") { // Update forum count update_forum_counters($thread['fid'], $updated_counters); }
$plugins->run_hooks("class_moderation_delete_thread", $tid);
|
return true; }
| return true; }
|
Zeile 221 | Zeile 249 |
---|
*/ function delete_poll($pid) {
|
*/ function delete_poll($pid) {
|
global $db;
| global $db, $plugins;
$plugins->run_hooks("class_moderation_delete_poll", $pid);
|
$db->delete_query(TABLE_PREFIX."polls", "pid='$pid'"); $db->delete_query(TABLE_PREFIX."pollvotes", "pid='$pid'"); $pollarray = array( "poll" => '',
|
$db->delete_query(TABLE_PREFIX."polls", "pid='$pid'"); $db->delete_query(TABLE_PREFIX."pollvotes", "pid='$pid'"); $pollarray = array( "poll" => '',
|
);
| );
|
$db->update_query(TABLE_PREFIX."threads", $pollarray, "poll='$pid'");
|
$db->update_query(TABLE_PREFIX."threads", $pollarray, "poll='$pid'");
|
|
|
return true; }
|
return true; }
|
|
|
/** * Approve one or more threads *
| /** * Approve one or more threads *
|
Zeile 241 | Zeile 271 |
---|
* @return boolean true */ function approve_threads($tids, $fid)
|
* @return boolean true */ function approve_threads($tids, $fid)
|
{ global $db, $cache;
if(!is_array($tids)) { $tids = array($tids); } $tid_list = implode(",", $tids);
$approve = array( "visible" => 1, ); $db->update_query(TABLE_PREFIX."threads", $approve, "tid IN ($tid_list)"); $db->update_query(TABLE_PREFIX."posts", $approve, "tid IN ($tid_list)", 1); foreach($tids as $tid)
| { global $db, $cache, $plugins;
if(!is_array($tids)) { $tids = array($tids); } $tid_list = implode(",", $tids); $num_threads = $num_posts = 0; foreach($tids as $tid)
|
{
|
{
|
update_thread_count($tid);
| $thread = get_thread($tid); if($thread['visible'] == 0) { $num_threads++; $num_posts += $thread['replies']+1; // Remove implied visible from count } $query = $db->query(" SELECT p.tid, f.usepostcounts, p.uid, p.visible FROM ".TABLE_PREFIX."posts p LEFT JOIN ".TABLE_PREFIX."forums f ON (f.fid=p.fid) WHERE p.tid='$tid' AND p.visible = '0' "); while($post = $db->fetch_array($query)) { // If post counts enabled in this forum and the post hasn't already been approved, remove 1 if($post['usepostcounts'] != "no") { $db->query("UPDATE ".TABLE_PREFIX."users SET postnum=postnum+1 WHERE uid='".$post['uid']."'"); } } $posts_to_approve[] = $thread['firstpost'];
|
}
|
}
|
| $approve = array( "visible" => 1, ); $db->update_query(TABLE_PREFIX."threads", $approve, "tid IN ($tid_list)"); $db->update_query(TABLE_PREFIX."posts", $approve, "tid IN (".implode(",", $posts_to_approve).")");
$plugins->run_hooks("class_moderation_approve_threads", $tids);
|
// Update stats
|
// Update stats
|
$cache->updatestats(); update_forum_count($fid);
| $update_array = array( "threads" => "+{$num_threads}", "unapprovedthreads" => "-{$num_threads}", "posts" => "+{$num_posts}", "unapprovedposts" => "-{$num_posts}" ); update_forum_counters($fid, $update_array);
|
return true; }
| return true; }
|
Zeile 277 | Zeile 337 |
---|
*/ function unapprove_threads($tids, $fid) {
|
*/ function unapprove_threads($tids, $fid) {
|
global $db, $cache;
| global $db, $cache, $plugins;
|
if(!is_array($tids))
|
if(!is_array($tids))
|
{
| {
|
$tids = array($tids);
|
$tids = array($tids);
|
}
| }
|
$tid_list = implode(",", $tids);
|
$tid_list = implode(",", $tids);
|
| $num_threads = $num_posts = 0; foreach($tids as $tid) { $thread = get_thread($tid); if($thread['visible'] == 1) { $num_threads++; $num_posts += $thread['replies']+1; // Add implied invisible to count } $query = $db->query(" SELECT p.tid, f.usepostcounts, p.uid, p.visible FROM ".TABLE_PREFIX."posts p LEFT JOIN ".TABLE_PREFIX."forums f ON (f.fid=p.fid) WHERE p.tid='$tid' AND p.visible = '1' "); while($post = $db->fetch_array($query)) { // If post counts enabled in this forum and the post hasn't already been unapproved, remove 1 if($post['usepostcounts'] != "no") { $db->query("UPDATE ".TABLE_PREFIX."users SET postnum=postnum-1 WHERE uid='".$post['uid']."'"); } } $posts_to_unapprove[] = $thread['firstpost']; }
|
$approve = array( "visible" => 0, ); $db->update_query(TABLE_PREFIX."threads", $approve, "tid IN ($tid_list)");
|
$approve = array( "visible" => 0, ); $db->update_query(TABLE_PREFIX."threads", $approve, "tid IN ($tid_list)");
|
$db->update_query(TABLE_PREFIX."posts", $approve, "tid IN ($tid_list) AND replyto='0'", 1);
| $db->update_query(TABLE_PREFIX."posts", $approve, "tid IN (".implode(",", $posts_to_unapprove).")");
$plugins->run_hooks("class_moderation_unapprove_threads", $tids);
|
|
|
foreach($tids as $tid) { update_thread_count($tid); }
| |
// Update stats
|
// Update stats
|
$cache->updatestats(); update_forum_count($fid);
return true; }
| $update_array = array( "threads" => "-{$num_threads}", "unapprovedthreads" => "+{$num_threads}", "posts" => "-{$num_posts}", "unapprovedposts" => "+{$num_posts}" ); update_forum_counters($fid, $update_array);
return true; }
|
/** * Delete a specific post *
| /** * Delete a specific post *
|
Zeile 321 | Zeile 410 |
---|
WHERE p.pid='$pid' "); $post = $db->fetch_array($query);
|
WHERE p.pid='$pid' "); $post = $db->fetch_array($query);
|
// If post counts enabled in this forum, remove 1 if($post['usepostcounts'] != "no")
| // If post counts enabled in this forum and it hasn't already been unapproved, remove 1 if($post['usepostcounts'] != "no" && $post['visible'] != 0)
|
{ $db->query("UPDATE ".TABLE_PREFIX."users SET postnum=postnum-1 WHERE uid='".$post['uid']."'"); }
| { $db->query("UPDATE ".TABLE_PREFIX."users SET postnum=postnum-1 WHERE uid='".$post['uid']."'"); }
|
Zeile 331 | Zeile 420 |
---|
// Remove attachments remove_attachments($pid);
|
// Remove attachments remove_attachments($pid);
|
| $num_unapproved_posts = $num_approved_posts = 0;
|
// Update unapproved post count if($post['visible'] == 0) {
|
// Update unapproved post count if($post['visible'] == 0) {
|
$db->query("UPDATE ".TABLE_PREFIX."forums SET unapprovedposts=unapprovedposts-1 WHERE fid='$post[fid]'"); $db->query("UPDATE ".TABLE_PREFIX."threads SET unapprovedposts=unapprovedposts-1 WHERE tid='$post[tid]'");
| $db->query("UPDATE ".TABLE_PREFIX."forums SET unapprovedposts=unapprovedposts-1 WHERE fid='{$post['fid']}'"); $db->query("UPDATE ".TABLE_PREFIX."threads SET unapprovedposts=unapprovedposts-1 WHERE tid='{$post['tid']}'"); $num_unaproved_posts--;
|
}
|
}
|
$plugins->run_hooks("delete_post", $post['tid']); $cache->updatestats(); update_thread_count($post['tid']); update_forum_count($post['fid']);
| else { $num_approved_posts++; } $plugins->run_hooks("class_moderation_delete_post", $post['pid']);
// Update stats $update_array = array( "replies" => "-{$num_approved_posts}", "unapprovedposts" => "-{$num_unapproved_posts}" ); update_thread_counters($post['tid'], $update_array); // Update stats $update_array = array( "posts" => "-{$num_approved_posts}", "unapprovedposts" => "-{$num_unapproved_posts}" ); update_forum_counters($post['fid'], $update_array);
|
return true; }
| return true; }
|
Zeile 354 | Zeile 462 |
---|
*/ function merge_posts($pids, $tid, $sep="new_line") {
|
*/ function merge_posts($pids, $tid, $sep="new_line") {
|
global $db;
| global $db, $plugins;
|
$pidin = implode(",", $pids); $first = 1; // Get the messages to be merged
|
$pidin = implode(",", $pids); $first = 1; // Get the messages to be merged
|
$query = $db->simple_select(TABLE_PREFIX."posts", "*", "tid='$tid' AND pid IN($pidin)", array('order_by' => 'dateline')); $num_unapproved_posts = 0;
| $query = $db->query(" SELECT p.pid, p.uid, p.fid, p.tid, p.visible, p.message, f.usepostcounts FROM ".TABLE_PREFIX."posts p LEFT JOIN ".TABLE_PREFIX."forums f ON (f.fid=p.fid) WHERE p.tid='$tid' AND p.pid IN($pidin) ORDER BY dateline ASC "); $num_unapproved_posts = $num_approved_posts = 0;
|
$message = ''; while($post = $db->fetch_array($query)) {
| $message = ''; while($post = $db->fetch_array($query)) {
|
Zeile 368 | Zeile 482 |
---|
{ // all posts will be merged into this one $masterpid = $post['pid']; $message = $post['message'];
|
{ // all posts will be merged into this one $masterpid = $post['pid']; $message = $post['message'];
|
| $fid = $post['fid'];
|
$first = 0; } else { // these are the selected posts if($sep == "new_line") {
|
$first = 0; } else { // these are the selected posts if($sep == "new_line") {
|
$message .= "\n\n $post[message]";
| $message .= "\n\n {$post['message']}";
|
} else {
|
} else {
|
$message .= "[hr]$post[message]";
| $message .= "[hr]{$post['message']}"; } if($post['usepostcounts'] != "no" && $post['visible'] == '1') { // Update post count of the user of the merged posts $db->query("UPDATE ".TABLE_PREFIX."users SET postnum=postnum-1 WHERE uid='{$post['uid']}'"); } if($post['visible'] == 1) { $num_approved_posts++; } elseif($post['visible'] == 0) { $num_unapproved_posts++;
|
} } }
|
} } }
|
$fid = $post['fid'];
| // Get lastpost pid to check if we're merging a post that is on the lastpost info $query = $db->simple_select(TABLE_PREFIX."posts", "pid", "tid = '{$post['tid']}'", array('order_by' => 'dateline', 'order_dir' => 'desc', 'limit' => '1')); $lastpostpid = $db->fetch_field($query, 'pid');
|
// Update the message $mergepost = array( "message" => $db->escape_string($message), );
|
// Update the message $mergepost = array( "message" => $db->escape_string($message), );
|
$db->update_query(TABLE_PREFIX."posts", $mergepost, "pid='$masterpid'");
| $db->update_query(TABLE_PREFIX."posts", $mergepost, "pid = '$masterpid'");
|
$db->delete_query(TABLE_PREFIX."posts", "pid IN($pidin) AND pid != '$masterpid'"); // Update pid for attachments $mergepost2 = array(
| $db->delete_query(TABLE_PREFIX."posts", "pid IN($pidin) AND pid != '$masterpid'"); // Update pid for attachments $mergepost2 = array(
|
Zeile 397 | Zeile 528 |
---|
); $db->update_query(TABLE_PREFIX."posts", $mergepost2, "pid IN($pidin)"); $db->update_query(TABLE_PREFIX."attachments", $mergepost2, "pid IN($pidin)");
|
); $db->update_query(TABLE_PREFIX."posts", $mergepost2, "pid IN($pidin)"); $db->update_query(TABLE_PREFIX."attachments", $mergepost2, "pid IN($pidin)");
|
| $plugins->run_hooks("class_moderation_merge_posts", array("pids" => $pids, "tid" => $tid));
|
// Update stats
|
// Update stats
|
update_thread_count($tid); update_forum_count($fid);
| $update_array = array( "replies" => "-{$num_approved_posts}", "unapprovedposts" => "-{$num_unapproved_posts}" ); update_thread_counters($tid, $update_array);
// Update stats $update_array = array( "posts" => "-{$num_approved_posts}", "unapprovedposts" => "-{$num_unapproved_posts}" ); update_forum_counters($fid, $update_array);
|
return true; }
| return true; }
|
Zeile 423 | Zeile 566 |
---|
$newforum = get_forum($new_fid); $fid = $thread['fid']; $forum = get_forum($fid);
|
$newforum = get_forum($new_fid); $fid = $thread['fid']; $forum = get_forum($fid);
|
| $num_threads = $num_unapproved_threads = $num_posts = $num_unapproved_threads = 0;
|
switch($method) { case "redirect": // move (and leave redirect) thread
|
switch($method) { case "redirect": // move (and leave redirect) thread
|
$plugins->run_hooks("moderation_do_move_redirect");
| $plugins->run_hooks("class_moderation_move_thread_redirect", array("tid" => $tid, "new_fid" => $new_fid)); if($thread['visible'] == 1) { $num_threads++; } else { $num_unapproved_threads++; // Implied forum unapproved count for unapproved threads $num_unapproved_posts = $thread['replies']+1; }
$num_posts = $thread['replies']+1; $num_unapproved_posts += $thread['unapprovedposts'];
|
$db->delete_query(TABLE_PREFIX."threads", "closed='moved|$tid' AND fid='$moveto'"); $changefid = array(
| $db->delete_query(TABLE_PREFIX."threads", "closed='moved|$tid' AND fid='$moveto'"); $changefid = array(
|
Zeile 436 | Zeile 594 |
---|
$db->update_query(TABLE_PREFIX."posts", $changefid, "tid='$tid'"); $threadarray = array( "fid" => $thread['fid'],
|
$db->update_query(TABLE_PREFIX."posts", $changefid, "tid='$tid'"); $threadarray = array( "fid" => $thread['fid'],
|
"subject" => $db->escape_string($thread['subject']), "icon" => $thread['icon'],
| "subject" => $db->escape_string($thread['subject']), "icon" => $thread['icon'],
|
"uid" => $thread['uid'], "username" => $db->escape_string($thread['username']), "dateline" => $thread['dateline'],
| "uid" => $thread['uid'], "username" => $db->escape_string($thread['username']), "dateline" => $thread['dateline'],
|
Zeile 447 | Zeile 605 |
---|
"views" => 0, "replies" => 0, "closed" => "moved|$tid",
|
"views" => 0, "replies" => 0, "closed" => "moved|$tid",
|
"sticky" => $thread['sticky'], "visible" => $thread['visible'], );
| "sticky" => $thread['sticky'], "visible" => $thread['visible'], "notes" => '' );
|
$db->insert_query(TABLE_PREFIX."threads", $threadarray); if($redirect_expire) {
| $db->insert_query(TABLE_PREFIX."threads", $threadarray); if($redirect_expire) {
|
Zeile 458 | Zeile 617 |
---|
} break; case "copy":// copy thread
|
} break; case "copy":// copy thread
|
// we need to add code to copy attachments(?), polls, etc etc here
|
|
$threadarray = array( "fid" => $new_fid, "subject" => $db->escape_string($thread['subject']),
| $threadarray = array( "fid" => $new_fid, "subject" => $db->escape_string($thread['subject']),
|
Zeile 475 | Zeile 634 |
---|
"sticky" => $thread['sticky'], "visible" => $thread['visible'], "unapprovedposts" => $thread['unapprovedposts'],
|
"sticky" => $thread['sticky'], "visible" => $thread['visible'], "unapprovedposts" => $thread['unapprovedposts'],
|
); $plugins->run_hooks("moderation_do_move_copy");
| "notes" => '' );
if($thread['visible'] == 1) { ++$num_threads; } else { $num_unapproved_threads++; // Implied forum unapproved count for unapproved threads $num_unapproved_posts = $thread['replies']+1; } $plugins->run_hooks("class_moderation_copy_thread", array("tid" => $tid, "new_fid" => $new_fid));
|
$db->insert_query(TABLE_PREFIX."threads", $threadarray); $newtid = $db->insert_id();
|
$db->insert_query(TABLE_PREFIX."threads", $threadarray); $newtid = $db->insert_id();
|
$query = $db->simple_select(TABLE_PREFIX."posts", "*", "tid='$tid'"); $postsql = '';
| if($thread['poll'] != 0) { $query = $db->simple_select(TABLE_PREFIX."polls", "*", "tid = '{$thread['tid']}'"); $poll = $db->fetch_array($query);
$poll_array = array( 'tid' => $newtid, 'question' => $db->escape_string($poll['question']), 'dateline' => $poll['dateline'], 'options' => $db->escape_string($poll['options']), 'votes' => $poll['votes'], 'numoptions' => $poll['numoptions'], 'numvotes' => $poll['numvotes'], 'timeout' => $poll['timeout'], 'closed' => $poll['closed'], 'multiple' => $poll['multiple'], 'public' => $poll['public'] ); $db->insert_query(TABLE_PREFIX."polls", $poll_array); $new_pid = $db->insert_id();
$query = $db->simple_select(TABLE_PREFIX."pollvotes", "*", "pid = '{$poll['pid']}'"); while($pollvote = $db->fetch_array($query)) { $pollvote_array = array( 'pid' => $new_pid, 'uid' => $pollvote['uid'], 'voteoption' => $pollvote['voteoption'], 'dateline' => $pollvote['dateline'], ); $db->insert_query(TABLE_PREFIX."pollvotes", $pollvote_array); }
$db->update_query(TABLE_PREFIX."threads", array('poll' => $new_pid), "tid='{$newtid}'"); } $query = $db->simple_select(TABLE_PREFIX."posts", "*", "tid = '{$thread['tid']}'");
|
while($post = $db->fetch_array($query)) {
|
while($post = $db->fetch_array($query)) {
|
if($postssql != '')
| $post_array = array( 'tid' => $newtid, 'fid' => $new_fid, 'subject' => $db->escape_string($post['subject']), 'icon' => $post['icon'], 'uid' => $post['uid'], 'username' => $db->escape_string($post['username']), 'dateline' => $post['dateline'], 'message' => $db->escape_string($post['message']), 'ipaddress' => $post['ipaddress'], 'includesig' => $post['includesig'], 'smilieoff' => $post['smilieoff'], 'edituid' => $post['edituid'], 'edittime' => $post['edittime'], 'visible' => $post['visible'] ); $db->insert_query(TABLE_PREFIX."posts", $post_array); $pid = $db->insert_id(); // Insert attachments for this post $query2 = $db->simple_select(TABLE_PREFIX."attachments", "*", "pid = '{$post['pid']}'"); while($attachment = $db->fetch_array($query2))
|
{
|
{
|
$postssql .= ", ";
| $attachment_array = array( 'pid' => $pid, 'posthash' => $db->escape_string($attachment['posthash']), 'uid' => $attachment['uid'], 'filename' => $db->escape_string($attachment['filename']), 'filetype' => $attachment['filetype'], 'filesize' => $attachment['filesize'], 'attachname' => $attachment['attachname'], 'downloads' => $attachment['downloads'], 'visible' => $attachment['visible'], 'thumbnail' => $attachment['thumbnail'] ); $db->insert_query(TABLE_PREFIX."attachments", $attachment_array);
|
}
|
}
|
$post['message'] = $db->escape_string($post['message']); $postssql .= "('$newtid','$new_fid','$post[subject]','$post[icon]','$post[uid]','$post[username]','$post[dateline]','$post[message]','$post[ipaddress]','$post[includesig]','$post[smilieoff]','$post[edituid]','$post[edittime]','$post[visible]')";
| |
}
|
}
|
$db->query("INSERT INTO ".TABLE_PREFIX."posts (tid,fid,subject,icon,uid,username,dateline,message,ipaddress,includesig,smilieoff,edituid,edittime,visible) VALUES $postssql"); update_first_post($newtid); update_thread_count($newtid);
| update_thread_data($newtid);
|
$the_thread = $newtid; break; default: case "move": // plain move thread
|
$the_thread = $newtid; break; default: case "move": // plain move thread
|
$plugins->run_hooks("moderation_do_move_simple");
| $plugins->run_hooks("class_moderation_move_simple", array("tid" => $tid, "new_fid" => $new_fid)); if($thread['visible'] == 1) { $num_threads++; } else { $num_unapproved_threads++; // Implied forum unapproved count for unapproved threads $num_unapproved_posts = $thread['replies']+1; }
$num_posts = $thread['replies']+1; $num_unapproved_posts = $thread['unapprovedposts'];
|
$sqlarray = array( "fid" => $new_fid,
| $sqlarray = array( "fid" => $new_fid,
|
Zeile 510 | Zeile 761 |
---|
}
// Do post count changes if changing between countable and non-countable forums
|
}
// Do post count changes if changing between countable and non-countable forums
|
$query = $db->query("
| $query = $db->query("
|
SELECT COUNT(p.pid) AS posts, u.uid FROM ".TABLE_PREFIX."posts p LEFT JOIN ".TABLE_PREFIX."users u ON (u.uid=p.uid)
| SELECT COUNT(p.pid) AS posts, u.uid FROM ".TABLE_PREFIX."posts p LEFT JOIN ".TABLE_PREFIX."users u ON (u.uid=p.uid)
|
Zeile 519 | Zeile 770 |
---|
ORDER BY posts DESC "); while($posters = $db->fetch_array($query))
|
ORDER BY posts DESC "); while($posters = $db->fetch_array($query))
|
{ if($method == "copy" && $newforum['usepostcounts'] != "no") { $pcount = "+$posters[posts]"; } elseif($method != "copy" && ($newforum['usepostcounts'] != "no" && $forum['usepostcounts'] == "no")) { $pcount = "+$posters[posts]"; } elseif($method != "copy" && ($newforum['usepostcounts'] == "no" && $forum['usepostcounts'] != "no")) { $pcount = "-$posters[posts]";
| { if($method == "copy" && $newforum['usepostcounts'] != "no" && $posters['visible'] != "no") { $pcount = "+{$posters['posts']}"; } elseif($method != "copy" && ($newforum['usepostcounts'] != "no" && $forum['usepostcounts'] == "no" && $posters['visible'] != "no")) { $pcount = "+{$posters['posts']}"; } elseif($method != "copy" && ($newforum['usepostcounts'] == "no" && $forum['usepostcounts'] != "no" && $posters['visible'] != "no")) { $pcount = "-{$posters['posts']}";
|
} if(!empty($pcount)) {
|
} if(!empty($pcount)) {
|
$db->query("UPDATE ".TABLE_PREFIX."users SET postnum=postnum$pcount WHERE uid='$posters[uid]'");
| $db->query("UPDATE ".TABLE_PREFIX."users SET postnum=postnum$pcount WHERE uid='{$posters['uid']}'");
|
}
|
}
|
}
| }
|
// Update forum counts
|
// Update forum counts
|
if($fid != $new_fid) { update_forum_count($new_fid);
| $update_array = array( "threads" => "+{$num_threads}", "unapprovedthreads" => "+{$num_unapproved_threads}", "posts" => "+{$num_posts}", "unapprovedposts" => "+{$num_unapproved_posts}" ); update_forum_counters($new_fid, $update_array); if($method != "copy") { $update_array = array( "threads" => "-{$num_threads}", "unapprovedthreads" => "-{$num_unapproved_threads}", "posts" => "-{$num_posts}", "unapprovedposts" => "-{$num_unapproved_posts}" ); update_forum_counters($fid, $update_array);
|
}
|
}
|
update_forum_count($fid);
| |
if(isset($newtid)) { return $newtid;
|
if(isset($newtid)) { return $newtid;
|
}
| }
|
else {
|
else {
|
| // Remove thread subscriptions for the users who no longer have permission to view the thread $this->remove_thread_subscriptions($tid, false, $new_fid);
|
return $tid; } }
| return $tid; } }
|
Zeile 565 | Zeile 832 |
---|
*/ function merge_threads($mergetid, $tid, $subject) {
|
*/ function merge_threads($mergetid, $tid, $subject) {
|
global $db, $mybb, $mergethread, $thread;
| global $db, $mybb, $mergethread, $thread, $plugins;
$mergetid = intval($mergetid); $tid = intval($tid);
|
if(!isset($mergethread['tid']) || $mergethread['tid'] != $mergetid)
|
if(!isset($mergethread['tid']) || $mergethread['tid'] != $mergetid)
|
{ $mergetid = intval($mergetid); $query = $db->simple_select(TABLE_PREFIX."threads", "*", "tid='".intval($mergetid)."'");
| { $query = $db->simple_select(TABLE_PREFIX."threads", "*", "tid='{$mergetid}'");
|
$mergethread = $db->fetch_array($query);
|
$mergethread = $db->fetch_array($query);
|
}
| }
|
if(!isset($thread['tid']) || $thread['tid'] != $tid) {
|
if(!isset($thread['tid']) || $thread['tid'] != $tid) {
|
$tid = intval($tid); $query = $db->simple_select(TABLE_PREFIX."threads", "*", "tid='".intval($tid)."'");
| $query = $db->simple_select(TABLE_PREFIX."threads", "*", "tid='{$tid}'");
|
$thread = $db->fetch_array($query);
|
$thread = $db->fetch_array($query);
|
}
| }
|
$pollsql = ''; if($mergethread['poll']) {
|
$pollsql = ''; if($mergethread['poll']) {
|
$pollsql = ", poll='$mergethread[poll]'";
| $pollsql['poll'] = $mergethread['poll'];
|
$sqlarray = array( "tid" => $tid, );
| $sqlarray = array( "tid" => $tid, );
|
Zeile 590 | Zeile 858 |
---|
} else {
|
} else {
|
$query = $db->simple_select(TABLE_PREFIX."threads", "*", "poll='{$mergethread['poll']}' AND tid != '".intval($mergetid)."'");
| $query = $db->simple_select(TABLE_PREFIX."threads", "*", "poll='{$mergethread['poll']}' AND tid != '{$mergetid}'");
|
$pollcheck = $db->fetch_array($query); if(!$pollcheck['poll']) {
| $pollcheck = $db->fetch_array($query); if(!$pollcheck['poll']) {
|
Zeile 607 | Zeile 875 |
---|
"replyto" => 0 ); $db->update_query(TABLE_PREFIX."posts", $sqlarray, "tid='$mergetid'");
|
"replyto" => 0 ); $db->update_query(TABLE_PREFIX."posts", $sqlarray, "tid='$mergetid'");
|
$db->query("UPDATE ".TABLE_PREFIX."threads SET subject='$subject' $pollsql WHERE tid='$tid'");
| $pollsql['subject'] = $subject; $db->update_query(TABLE_PREFIX."threads", $pollsql, "tid='$tid'");
|
$sqlarray = array( "closed" => "moved|$tid", ); $db->update_query(TABLE_PREFIX."threads", $sqlarray, "closed='moved|$mergetid'"); $sqlarray = array( "tid" => $tid,
|
$sqlarray = array( "closed" => "moved|$tid", ); $db->update_query(TABLE_PREFIX."threads", $sqlarray, "closed='moved|$mergetid'"); $sqlarray = array( "tid" => $tid,
|
);
| );
|
$db->update_query(TABLE_PREFIX."favorites", $sqlarray, "tid='$mergetid'"); update_first_post($tid);
|
$db->update_query(TABLE_PREFIX."favorites", $sqlarray, "tid='$mergetid'"); update_first_post($tid);
|
| $plugins->run_hooks("class_moderation_merge_threads", array("mergetid" => $tid, "tid" => $tid, "subject" => $subject));
|
$this->delete_thread($mergetid);
|
$this->delete_thread($mergetid);
|
update_thread_count($tid); if($thread['fid'] != $mergethread['fid'])
| $updated_stats = array( "replies" => '+'.$mergethread['replies']+1, "unapprovedposts" => "+{$mergethread['unapprovedposts']}" ); update_thread_counters($tid, $updated_stats);
// Thread is not in current forum if($mergethread['fid'] != $thread['fid']) { // If old thread was unapproved, implied counter for old forum needs updating if($mergethread['visible'] == 0) { $updated_stats = array( "unapprovedposts" => '-'.($mergethread['replies']+$mergethread['unapprovedposts']) ); } else { $updated_stats = array( "posts" => '-'.($mergethread['replies']+1), "unapprovedposts" => "-{$mergethread['unapprovedposts']}" ); } update_forum_counters($mergethread['fid'], $updated_stats); // If new thread is unapproved, implied counter comes in to effect if($thread['visible'] == 0) { $updated_stats = array( "unapprovedposts" => '+'.($mergethread['replies']+$mergethread['unapprovedposts']) ); } else { $updated_stats = array( "posts" => '+'.($mergethread['replies']+1), "unapprovedposts" => "+{$mergethread['unapprovedposts']}" ); } update_forum_counters($thread['fid'], $updated_stats); } // Merged thread and new thread are in the same forum else
|
{
|
{
|
update_forum_count($mergethread['fid']);
| if($mergethread['visible'] == 0) { $updated_stats = array( "unapprovedthreads" => "-1" ); } else { $updated_stats = array( "threads" => "-1" ); } update_forum_counters($thread['fid'], $updated_stats);
|
}
|
}
|
update_forum_count($fid);
| |
return true; }
| return true; }
|
Zeile 639 | Zeile 962 |
---|
* @param string New thread subject * @param int TID if moving into existing thread * @return int New thread ID
|
* @param string New thread subject * @param int TID if moving into existing thread * @return int New thread ID
|
*/
| */
|
function split_posts($pids, $tid, $moveto, $newsubject, $destination_tid=0) {
|
function split_posts($pids, $tid, $moveto, $newsubject, $destination_tid=0) {
|
global $db, $thread;
| global $db, $thread, $plugins;
|
if(!isset($thread['tid']) || $thread['tid'] != $tid) {
| if(!isset($thread['tid']) || $thread['tid'] != $tid) {
|
Zeile 654 | Zeile 977 |
---|
// Create the new thread $newsubject = $db->escape_string($newsubject); $query = array(
|
// Create the new thread $newsubject = $db->escape_string($newsubject); $query = array(
|
"fid" => $moveto, "subject" => $newsubject, "icon" => $thread['icon'], "uid" => $thread['uid'], "username" => $thread['username'], "dateline" => $thread['dateline'], "lastpost" => $thread['lastpost'], "lastposter" => $thread['lastposter'],
| "fid" => intval($moveto), "subject" => $db->escape_string($newsubject), "icon" => $db->escape_string($thread['icon']), "uid" => $db->escape_string($thread['uid']), "username" => $db->escape_string($thread['username']), "dateline" => $db->escape_string($thread['dateline']), "lastpost" => $db->escape_string($thread['lastpost']), "lastposter" => $db->escape_string($thread['lastposter']),
|
"replies" => count($pids)-1, "visible" => "1",
|
"replies" => count($pids)-1, "visible" => "1",
|
);
| "notes" => '' );
|
$db->insert_query(TABLE_PREFIX."threads", $query); $newtid = $db->insert_id();
| $db->insert_query(TABLE_PREFIX."threads", $query); $newtid = $db->insert_id();
|
Zeile 672 | Zeile 996 |
---|
$pids_list = implode(",", $pids); $sqlarray = array( "tid" => $newtid,
|
$pids_list = implode(",", $pids); $sqlarray = array( "tid" => $newtid,
|
"fid" => $moveto, "replyto" => 0 );
| "fid" => $moveto, "replyto" => 0 );
|
$db->update_query(TABLE_PREFIX."posts", $sqlarray, "pid IN ($pids_list)");
// adjust user post counts accordingly
| $db->update_query(TABLE_PREFIX."posts", $sqlarray, "pid IN ($pids_list)");
// adjust user post counts accordingly
|
Zeile 683 | Zeile 1007 |
---|
$query = $db->simple_select(TABLE_PREFIX."forums", "usepostcounts", "fid='$moveto'"); $newusepcounts = $db->fetch_field($query, "usepostcounts"); $query = $db->query("
|
$query = $db->simple_select(TABLE_PREFIX."forums", "usepostcounts", "fid='$moveto'"); $newusepcounts = $db->fetch_field($query, "usepostcounts"); $query = $db->query("
|
SELECT COUNT(p.pid) AS posts, u.uid
| SELECT COUNT(p.pid) AS posts, u.uid
|
FROM ".TABLE_PREFIX."posts p LEFT JOIN ".TABLE_PREFIX."users u ON (u.uid=p.uid)
|
FROM ".TABLE_PREFIX."posts p LEFT JOIN ".TABLE_PREFIX."users u ON (u.uid=p.uid)
|
WHERE p.tid='$tid'
| WHERE p.tid='$newtid' AND p.visible = '1'
|
GROUP BY u.uid ORDER BY posts DESC
|
GROUP BY u.uid ORDER BY posts DESC
|
");
| ");
|
while($posters = $db->fetch_array($query)) { if($oldusepcounts == "yes" && $newusepcounts == "no")
|
while($posters = $db->fetch_array($query)) { if($oldusepcounts == "yes" && $newusepcounts == "no")
|
{ $pcount = "-$posters[posts]";
| { $pcount = "-{$posters['posts']}";
|
} elseif($oldusepcounts == "no" && $newusepcounts == "yes")
|
} elseif($oldusepcounts == "no" && $newusepcounts == "yes")
|
{ $pcount = "+$posters[posts]"; }
| { $pcount = "+{$posters['posts']}"; }
|
if(!empty($pcount)) { $db->query("UPDATE ".TABLE_PREFIX."users SET postnum=postnum$pcount WHERE uid='{$posters['uid']}'");
|
if(!empty($pcount)) { $db->query("UPDATE ".TABLE_PREFIX."users SET postnum=postnum$pcount WHERE uid='{$posters['uid']}'");
|
} }
| } } $num_visible = $num_unnaproved = $num_attachments = 0; $query = $db->query(" SELECT p.visible, a.aid FROM ".TABLE_PREFIX."posts p LEFT JOIN ".TABLE_PREFIX."attachments a ON (a.pid=p.pid AND a.visible=1) WHERE p.tid='{$newtid}' "); while($post = $db->fetch_array($query)) { if($post['visible'] == 1) { $num_visible++; if($post['aid']) { $num_attachments++; } } else if($post['visible'] == 0) { $num_unapproved++; } }
|
// Update the subject of the first post in the new thread $query = $db->simple_select(TABLE_PREFIX."posts", "pid", "tid='$newtid'", array('order_by' => 'dateline', 'limit' => 1));
| // Update the subject of the first post in the new thread $query = $db->simple_select(TABLE_PREFIX."posts", "pid", "tid='$newtid'", array('order_by' => 'dateline', 'limit' => 1));
|
Zeile 714 | Zeile 1061 |
---|
"subject" => $newsubject, "replyto" => 0 );
|
"subject" => $newsubject, "replyto" => 0 );
|
$db->update_query(TABLE_PREFIX."posts", $sqlarray, "pid='$newthread[pid]'");
| $db->update_query(TABLE_PREFIX."posts", $sqlarray, "pid='{$newthread['pid']}'");
|
// Update the subject of the first post in the old thread $query = $db->simple_select(TABLE_PREFIX."posts", "pid", "tid='$tid'", array('order_by' => 'dateline', 'limit' => 1));
| // Update the subject of the first post in the old thread $query = $db->simple_select(TABLE_PREFIX."posts", "pid", "tid='$tid'", array('order_by' => 'dateline', 'limit' => 1));
|
Zeile 725 | Zeile 1072 |
---|
); $db->update_query(TABLE_PREFIX."posts", $sqlarray, "pid='{$oldthread['pid']}'");
|
); $db->update_query(TABLE_PREFIX."posts", $sqlarray, "pid='{$oldthread['pid']}'");
|
| $plugins->run_hooks("class_moderation_split_posts", array("pids" => $pids, "tid" => $tid, "moveto" => $moveto, "newsubject" => $newsubject, "destination_tid" => $destination_tid));
// Update old thread stats $update_array = array( "replies" => "-{$num_visible}", "unapprovedposts" => "-{$num_unapproved}", "attachmentcount" => "-{$num_attachments}" ); update_thread_counters($thread['tid'], $update_array);
// Update new thread stats $update_array = array( "replies" => $num_visible-1, "unapprovedposts" => $num_unapproved, "attachmentcount" => $num_attachments ); update_thread_counters($newtid, $update_array);
if($thread['fid'] != $moveto) { // Update old forum stats $update_array = array( "posts" => "-{$num_visible}", "unapprovedposts" => "-{$num_unapproved}" ); update_forum_counters($thread['fid'], $update_array);
// Update new forum stats $update_array = array( "posts" => "+{$num_visible}", "unapprovedposts" => "+{$num_unapproved}" ); } else { $update_array = array(); }
if($thread['visible'] == 1) { $update_array['threads'] = "+1"; } else if($thread['visible'] == 0) { $update_array['unapprovedthreads'] = "+1"; } update_forum_counters($moveto, $update_array);
// Update first post columns
|
update_first_post($tid); update_first_post($newtid);
|
update_first_post($tid); update_first_post($newtid);
|
update_thread_count($tid); update_thread_count($newtid); if($moveto != $thread['fid']) { update_forum_count($moveto); } update_forum_count($thread['fid']);
| |
// Merge new thread with destination thread if specified if($destination_tid)
| // Merge new thread with destination thread if specified if($destination_tid)
|
Zeile 753 | Zeile 1142 |
---|
*/ function move_threads($tids, $moveto) {
|
*/ function move_threads($tids, $moveto) {
|
global $db;
| global $db, $plugins;
|
$tid_list = implode(",", $tids);
|
$tid_list = implode(",", $tids);
|
$query = $db->simple_select(TABLE_PREFIX."threads", "fid", "tid IN ($tid_list)");
| $newforum = get_forum($moveto); $total_posts = $total_unapproved_posts = $total_threads = $total_unapproved_threads = 0; $query = $db->simple_select(TABLE_PREFIX."threads", "fid, visible, replies, unapprovedposts", "tid IN ($tid_list)");
|
while($thread = $db->fetch_array($query)) {
|
while($thread = $db->fetch_array($query)) {
|
$update_forums[$thread['fid']] = $thread['fid'];
| $forum = get_forum($thread['fid']); $total_posts += $thread['replies']+1; $total_unapproved_posts += $thread['unapprovedposts']; $forum_counters[$thread['fid']]['posts'] += $thread['replies']+1; $forum_counters[$thread['fid']]['unapprovedposts'] += $thread['unapprovedposts']; if($thread['visible'] == 1) { $forum_counters[$thread['fid']]['threads']++; ++$total_threads; } else { $forum_counters[$thread['fid']]['unapprovedthreads']++; $forum_counters[$thread['fid']]['unapprovedposts'] += $thread['replies']; // Implied unapproved posts counter for unapproved threads ++$total_unapproved_threads; } $query1 = $db->query(" SELECT COUNT(p.pid) AS posts, u.uid FROM ".TABLE_PREFIX."posts p LEFT JOIN ".TABLE_PREFIX."users u ON (u.uid=p.uid) WHERE tid='{$thread['tid']}' GROUP BY u.uid ORDER BY posts DESC "); while($posters = $db->fetch_array($query1)) { if($method == "copy" && $newforum['usepostcounts'] != "no" && $posters['visible'] != "no") { $pcount = "+{$posters['posts']}"; } elseif($method != "copy" && ($newforum['usepostcounts'] != "no" && $forum['usepostcounts'] == "no" && $posters['visible'] != "no")) { $pcount = "+{$posters['posts']}"; } elseif($method != "copy" && ($newforum['usepostcounts'] == "no" && $forum['usepostcounts'] != "no" && $posters['visible'] != "no")) { $pcount = "-{$posters['posts']}"; } if(!empty($pcount)) { $db->query("UPDATE ".TABLE_PREFIX."users SET postnum=postnum$pcount WHERE uid='{$posters['uid']}'"); } }
|
}
|
}
|
|
|
$sqlarray = array( "fid" => $moveto, ); $db->update_query(TABLE_PREFIX."threads", $sqlarray, "tid IN ($tid_list)");
|
$sqlarray = array( "fid" => $moveto, ); $db->update_query(TABLE_PREFIX."threads", $sqlarray, "tid IN ($tid_list)");
|
$db->update_query(TABLE_PREFIX."posts", $sqlarray, "tid IN ($tid_list)");
| $db->update_query(TABLE_PREFIX."posts", $sqlarray, "tid IN ($tid_list)");
$plugins->run_hooks("class_moderation_move_threads", array("tids" => $tids, "moveto" => $moveto));
|
|
|
update_forum_count($moveto); foreach($update_forums as $fid) { update_forum_count($fid); }
| foreach($forum_counters as $fid => $counter) { $updated_count = array( "posts" => "-{$counter['posts']}", "unapprovedposts" => "-{$counter['unapprovedposts']}" ); if($counter['threads']) { $updated_count['threads'] = "-{$counter['threads']}"; } if($counter['unapprovedthreads']) { $updated_count['unapprovedthreads'] = "-{$counter['unapprovedthreads']}"; } update_forum_counters($fid, $updated_count); // Do post count changes if changing between countable and non-countable forums }
$updated_count = array( "threads" => "+{$total_threads}", "unapprovedthreads" => "+{$total_unapproved_threads}", "posts" => "+{$total_posts}", "unapprovedposts" => "+{$total_unapproved_posts}" );
update_forum_counters($moveto, $updated_count); // Remove thread subscriptions for the users who no longer have permission to view the thread $this->remove_thread_subscriptions($tid_list, false, $moveto);
|
return true; }
/** * Approve multiple posts
|
return true; }
/** * Approve multiple posts
|
* * @param array PIDs * @param int Thread ID * @param int Forum ID * @return boolean true */
| * * @param array PIDs * @param int Thread ID * @param int Forum ID * @return boolean true */
|
function approve_posts($pids, $tid, $fid) {
|
function approve_posts($pids, $tid, $fid) {
|
global $db, $cache;
| global $db, $cache, $plugins;
|
$thread = get_thread($tid);
|
$thread = get_thread($tid);
|
| $num_posts = 0; foreach($pids as $pid) { $query = $db->query(" SELECT p.tid, f.usepostcounts, p.uid, p.visible FROM ".TABLE_PREFIX."posts p LEFT JOIN ".TABLE_PREFIX."forums f ON (f.fid=p.fid) WHERE p.pid='{$pid}' AND p.visible = '0' "); while($post = $db->fetch_array($query)) { // If post counts enabled in this forum and the post hasn't already been approved, add 1 if($post['usepostcounts'] != "no") { $db->query("UPDATE ".TABLE_PREFIX."users SET postnum=postnum+1 WHERE uid='".$post['uid']."'"); } ++$num_posts; } }
|
$where = "pid IN (".implode(",", $pids).")";
// Make visible $approve = array( "visible" => 1,
|
$where = "pid IN (".implode(",", $pids).")";
// Make visible $approve = array( "visible" => 1,
|
);
| );
|
$db->update_query(TABLE_PREFIX."posts", $approve, $where);
|
$db->update_query(TABLE_PREFIX."posts", $approve, $where);
|
// If this is the first post of the thread, also approve the thread $query = $db->simple_select(TABLE_PREFIX."posts", "tid", "pid='{$thread['firstpost']}' AND visible='1'");
| $plugins->run_hooks("class_moderation_approve_posts", $pids);
$is_first = false; // If this is the first post of the thread, also approve the thread $query = $db->simple_select(TABLE_PREFIX."posts", "tid, pid", "pid='{$thread['firstpost']}' AND visible='1'");
|
$first_post = $db->fetch_array($query); if($first_post['tid']) {
|
$first_post = $db->fetch_array($query); if($first_post['tid']) {
|
$db->update_query(TABLE_PREFIX."threads", $approve, "tid='{$first_post['tid']}'");
| if(in_array($first_post['pid'], $pids)) { $is_first = true; // Thread is invisible, update impled counters if($thread['visible'] == 0) { $num_posts += $thread['replies']; } $db->update_query(TABLE_PREFIX."threads", $approve, "tid='{$first_post['tid']}'"); } } if($is_first) { $updated_thread_stats['replies'] = "+".($num_posts-1); } else { $updated_thread_stats['replies'] = "+{$num_posts}";
|
}
|
}
|
update_thread_count($tid); update_forum_count($fid); $cache->updatestats();
| $updated_thread_stats['unapprovedposts'] = "-".$num_posts; update_thread_counters($tid, $updated_thread_stats); $updated_forum_stats = array( "posts" => "+{$num_posts}", "unapprovedposts" => "-{$num_posts}" ); if($is_first) { $updated_forum_stats['threads'] = "+1"; $updated_forum_stats['unapprovedthreads'] = "-1"; } update_forum_counters($fid, $updated_forum_stats);
|
return true; }
| return true; }
|
Zeile 817 | Zeile 1334 |
---|
* Unapprove multiple posts * * @param array PIDs
|
* Unapprove multiple posts * * @param array PIDs
|
* @param int Thread ID
| * @param int Thread ID
|
* @param int Forum ID * @return boolean true */ function unapprove_posts($pids, $tid, $fid) {
|
* @param int Forum ID * @return boolean true */ function unapprove_posts($pids, $tid, $fid) {
|
global $db, $cache;
| global $db, $cache, $plugins;
|
$thread = get_thread($tid);
|
$thread = get_thread($tid);
|
| $num_posts = 0; foreach($pids as $pid) { $query = $db->query(" SELECT p.tid, f.usepostcounts, p.uid FROM ".TABLE_PREFIX."posts p LEFT JOIN ".TABLE_PREFIX."forums f ON (f.fid=p.fid) WHERE p.pid='{$pid}' AND p.visible = '1' "); while($post = $db->fetch_array($query)) { // If post counts enabled in this forum and the post hasn't already been unapproved, remove 1 if($post['usepostcounts'] != "no") { $db->query("UPDATE ".TABLE_PREFIX."users SET postnum=postnum-1 WHERE uid='".$post['uid']."'"); } $num_posts++; } }
|
$where = "pid IN (".implode(",", $pids).")";
| $where = "pid IN (".implode(",", $pids).")";
|
Zeile 835 | Zeile 1372 |
---|
); $db->update_query(TABLE_PREFIX."posts", $unapprove, $where);
|
); $db->update_query(TABLE_PREFIX."posts", $unapprove, $where);
|
| $plugins->run_hooks("class_moderation_unapprove_posts", $pids);
$is_first = false;
|
// If this is the first post of the thread, also approve the thread
|
// If this is the first post of the thread, also approve the thread
|
$query = $db->simple_select(TABLE_PREFIX."posts", "tid", "pid='{$thread['firstpost']}' AND visible='0'");
| $query = $db->simple_select(TABLE_PREFIX."posts", "tid,pid", "pid='{$thread['firstpost']}' AND visible='0'");
|
$first_post = $db->fetch_array($query); if($first_post['tid']) {
|
$first_post = $db->fetch_array($query); if($first_post['tid']) {
|
$db->update_query(TABLE_PREFIX."threads", $unapprove, "tid='{$first_post['tid']}'");
| if(in_array($first_post['pid'], $pids)) { $is_first = true; // Thread is visible, update impled counters if($thread['visible'] == 1) { $num_posts += $thread['replies']; } $db->update_query(TABLE_PREFIX."threads", $unapprove, "tid='{$first_post['tid']}'"); }
|
}
|
}
|
update_thread_count($tid); update_forum_count($fid); $cache->updatestats();
| $updated_thread_stats = array( "unapprovedposts" => "+{$num_posts}" ); if($is_first) { $updated_thread_stats['replies'] = "-".($num_posts-1); } else { $updated_thread_stats['replies'] = "-{$num_posts}"; } update_thread_counters($tid, $updated_thread_stats);
$updated_forum_stats = array( "posts" => "-{$num_posts}", "unapprovedposts" => "+{$num_posts}" );
if($is_first) { $updated_forum_stats['threads'] = "-1"; $updated_forum_stats['unapprovedthreads'] = "+1"; } update_forum_counters($fid, $updated_forum_stats);
|
return true; }
/** * Change thread subject
|
return true; }
/** * Change thread subject
|
*
| *
|
* @param mixed Thread ID(s) * @param string Format of new subject (with {subject}) * @return boolean true */ function change_thread_subject($tids, $format) {
|
* @param mixed Thread ID(s) * @param string Format of new subject (with {subject}) * @return boolean true */ function change_thread_subject($tids, $format) {
|
global $db;
| global $db, $plugins;
|
// Get tids into list if(!is_array($tids)) { $tids = array(intval($tids));
|
// Get tids into list if(!is_array($tids)) { $tids = array(intval($tids));
|
}
| }
|
$tid_list = implode(",", $tids);
|
$tid_list = implode(",", $tids);
|
|
|
// Get original subject $query = $db->simple_select(TABLE_PREFIX."threads", "subject, tid", "tid IN ($tid_list)"); while($thread = $db->fetch_array($query))
| // Get original subject $query = $db->simple_select(TABLE_PREFIX."threads", "subject, tid", "tid IN ($tid_list)"); while($thread = $db->fetch_array($query))
|
Zeile 877 | Zeile 1447 |
---|
); $db->update_query(TABLE_PREFIX."threads", $new_subject, "tid='{$thread['tid']}'", 1); $db->update_query(TABLE_PREFIX."posts", $new_subject, "tid='{$thread['tid']}' AND replyto='0'", 1);
|
); $db->update_query(TABLE_PREFIX."threads", $new_subject, "tid='{$thread['tid']}'", 1); $db->update_query(TABLE_PREFIX."posts", $new_subject, "tid='{$thread['tid']}' AND replyto='0'", 1);
|
| $lastpost_subject = array( "lastpostsubject" => $new_subject['subject'] );
$db->update_query(TABLE_PREFIX."forums", $lastpost_subject, "lastposttid='{$thread['tid']}'");
|
}
|
}
|
| $plugins->run_hooks("class_moderation_change_thread_subject", array("tids" => $tids, "format" => $format));
|
return true; }
| return true; }
|
Zeile 890 | Zeile 1468 |
---|
* @return boolean true */ function expire_thread($tid, $deletetime)
|
* @return boolean true */ function expire_thread($tid, $deletetime)
|
{ global $db;
| { global $db, $plugins;
|
$update_thread = array( "deletetime" => intval($deletetime) ); $db->update_query(TABLE_PREFIX."threads", $update_thread, "tid='{$tid}'");
|
$update_thread = array( "deletetime" => intval($deletetime) ); $db->update_query(TABLE_PREFIX."threads", $update_thread, "tid='{$tid}'");
|
| $plugins->run_hooks("class_moderation_expire_thread", array("tid" => $tid, "deletetime" => $deletetime));
|
return true; }
| return true; }
|
Zeile 928 | Zeile 1508 |
---|
if(is_array($unapprove)) { $this->unapprove_posts($unapprove, $tid, $fid);
|
if(is_array($unapprove)) { $this->unapprove_posts($unapprove, $tid, $fid);
|
} if(is_array($approve)) { $this->approve_posts($approve, $tid, $fid); }
| } if(is_array($approve)) { $this->approve_posts($approve, $tid, $fid); }
|
return true; }
| return true; }
|
Zeile 944 | Zeile 1524 |
---|
* @return boolean true */ function toggle_thread_visibility($tids, $fid)
|
* @return boolean true */ function toggle_thread_visibility($tids, $fid)
|
{ global $db;
| { global $db;
|
$tid_list = implode(',', $tids); $query = $db->simple_select(TABLE_PREFIX."threads", 'tid, visible', "tid IN ($tid_list)"); while($thread = $db->fetch_array($query))
| $tid_list = implode(',', $tids); $query = $db->simple_select(TABLE_PREFIX."threads", 'tid, visible', "tid IN ($tid_list)"); while($thread = $db->fetch_array($query))
|
Zeile 986 | Zeile 1566 |
---|
if($thread['closed'] == "yes") { $open[] = $thread['tid'];
|
if($thread['closed'] == "yes") { $open[] = $thread['tid'];
|
}
| }
|
elseif($thread['closed'] == '')
|
elseif($thread['closed'] == '')
|
{
| {
|
$close[] = $thread['tid'];
|
$close[] = $thread['tid'];
|
} }
| } }
|
if(is_array($open))
|
if(is_array($open))
|
{
| {
|
$this->open_threads($open);
|
$this->open_threads($open);
|
}
| }
|
if(is_array($close)) { $this->close_threads($close); }
|
if(is_array($close)) { $this->close_threads($close); }
|
| return true; } /** * Remove thread subscriptions (from one or multiple threads in the same forum) * * @param int $tids Thread ID, or an array of thread IDs from the same forum. * @param boolean $all True (default) to delete all subscriptions, false to only delete subscriptions from users with no permission to read the thread * @param int $fid (Only applies if $all is false) The forum ID of the thread (if 0, will query database) * @return boolean true */ function remove_thread_subscriptions($tids, $all = true, $fid = 0) { global $db, $plugins; // Format thread IDs if(!is_array($tids)) { $tids = array($tids); } $tids_csv = implode(',', $tids); // Delete only subscriptions from users who no longer have permission to read the thread. if(!$all) { // Get forum ID if(!$fid) { $query = $db->simple_select(TABLE_PREFIX."threads", "fid", "tid='{$tid[0]}'"); } // Get groups that cannot view the forum or its threads $forum_parentlist = get_parent_list($fid); $query = $db->simple_select(TABLE_PREFIX."forumpermissions", "gid", "fid IN ({$forum_parentlist}) AND (canview='no' OR canviewthreads='no')"); $groups = array(); while($group = $db->fetch_array($query)) { $groups[] = $group['gid']; $additional_groups .= " OR CONCAT(',',u.additionalgroups,',') LIKE ',{$group['gid']},'"; } // If there are groups found, delete subscriptions from users in these groups if(count($groups) > 0) { $groups_csv = implode(',', $groups); $db->query("DELETE s FROM (".TABLE_PREFIX."favorites s, ".TABLE_PREFIX."users u) WHERE s.type='s' AND s.tid IN ({$tids_csv}) AND s.uid=u.uid AND (u.usergroup IN ({$groups_csv}){$additional_groups})"); } } // Delete all subscriptions of this thread else { $db->delete_query(TABLE_PREFIX."favorites", "tid IN ({$tids_csv}) AND type='s'"); }
$plugins->run_hooks("class_moderation_remove_thread_subscriptions", array("tids" => $tids, "all" => $all, "fid" => $fid));
|
return true; } }
| return true; } }
|