query("SELECT p.Body, p.AuthorID, p.TopicID, t.IsLocked, t.ForumID, f.MinClassWrite, CEIL((SELECT COUNT(ID) FROM forums_posts WHERE forums_posts.TopicID = p.TopicID AND forums_posts.ID <= '$PostID')/".POSTS_PER_PAGE.") AS Page FROM forums_posts as p JOIN forums_topics as t on p.TopicID = t.ID JOIN forums as f ON t.ForumID=f.ID WHERE p.ID='$PostID'"); list($OldBody, $AuthorID, $TopicID, $IsLocked, $ForumID, $MinClassWrite, $Page) = $DB->next_record(); // Make sure they aren't trying to edit posts they shouldn't // We use die() here instead of error() because whatever we spit out is displayed to the user in the box where his forum post is if(!check_forumperm($ForumID, 'Write') || ($IsLocked && !check_perms('site_moderate_forums'))) { error('Either the thread is locked, or you lack the permission to edit this post.',true); } if($UserID != $AuthorID && !check_perms('site_moderate_forums')) { error(403,true); } if($LoggedUser['DisablePosting']) { error('Your posting rights have been removed.',true); } if($DB->record_count()==0) { error(404,true); } // Send a PM to the user to notify them of the edit if($UserID != $AuthorID && $DoPM) { $PMSubject = 'Your post #'.$PostID.' has been edited'; $PMurl = 'https://'.NONSSL_SITE_URL.'/forums.php?action=viewthread&postid='.$PostID.'#post'.$PostID; $ProfLink = '[url=https://'.NONSSL_SITE_URL.'/user.php?id='.$UserID.']'.$LoggedUser['Username'].'[/url]'; $PMBody = 'One of your posts has been edited by '.$ProfLink.': [url]'.$PMurl.'[/url]'; Misc::send_pm($AuthorID,0,$PMSubject,$PMBody,$ConvID=''); } // Perform the update $DB->query("UPDATE forums_posts SET Body = '$Body', EditedUserID = '$UserID', EditedTime = '".$SQLTime."' WHERE ID='$PostID'"); $CatalogueID = floor((POSTS_PER_PAGE*$Page-POSTS_PER_PAGE)/THREAD_CATALOGUE); $Cache->begin_transaction('thread_'.$TopicID.'_catalogue_'.$CatalogueID); if ($Cache->MemcacheDBArray[$Key]['ID'] != $PostID) { $Cache->cancel_transaction(); $Cache->delete('thread_'.$TopicID.'_catalogue_'.$CatalogueID); //just clear the cache for would be cache-screwer-uppers } else { $Cache->update_row($Key, array( 'ID'=>$Cache->MemcacheDBArray[$Key]['ID'], 'AuthorID'=>$Cache->MemcacheDBArray[$Key]['AuthorID'], 'AddedTime'=>$Cache->MemcacheDBArray[$Key]['AddedTime'], 'Body'=>$_POST['body'], //Don't url decode. 'EditedUserID'=>$LoggedUser['ID'], 'EditedTime'=>$SQLTime, 'Username'=>$LoggedUser['Username'] )); $Cache->commit_transaction(3600*24*5); } $ThreadInfo = get_thread_info($TopicID); if($ThreadInfo['StickyPostID'] == $PostID) { $ThreadInfo['StickyPost']['Body'] = $_POST['body']; $ThreadInfo['StickyPost']['EditedUserID'] = $LoggedUser['ID']; $ThreadInfo['StickyPost']['EditedTime'] = $SQLTime; $Cache->cache_value('thread_'.$TopicID.'_info', $ThreadInfo, 0); } $DB->query("INSERT INTO comments_edits (Page, PostID, EditUser, EditTime, Body) VALUES ('forums', ".$PostID.", ".$UserID.", '".$SQLTime."', '".db_string($OldBody)."')"); $Cache->delete_value("forums_edits_$PostID"); // This gets sent to the browser, which echoes it in place of the old body echo $Text->full_format($_POST['body']); ?>

Last edited by just now