authInfo->isLoggedIn) Template::displayInfo('You must be logged in to manage posts.', 401); $currentUser = $msz->authInfo->userInfo; $currentUserId = $currentUser === null ? '0' : $currentUser->id; if($postMode !== '' && $msz->usersCtx->hasActiveBan($currentUser)) Template::displayInfo('You have been banned, check your profile for more information.', 403); try { $postInfo = $msz->forumCtx->posts->getPost(postId: $postId); } catch(RuntimeException $ex) { Template::throwError(404); } $perms = $msz->authInfo->getPerms('forum', $postInfo->categoryId); if(!$perms->check(Perm::F_CATEGORY_VIEW)) Template::throwError(403); $canDeleteAny = $perms->check(Perm::F_POST_DELETE_ANY); switch($postMode) { case 'delete': if($canDeleteAny) { if($postInfo->deleted) Template::displayInfo('This post has already been marked as deleted.', 404); } else { if($postInfo->deleted) Template::throwError(404); if(!$perms->check(Perm::F_POST_DELETE_OWN)) Template::displayInfo('You are not allowed to delete posts.', 403); if($postInfo->userId !== $currentUser->id) Template::displayInfo('You can only delete your own posts.', 403); // posts may only be deleted within a week of creation, this should be a config value $deleteTimeFrame = 60 * 60 * 24 * 7; if($postInfo->createdTime < time() - $deleteTimeFrame) Template::displayInfo('This post has existed for too long. Ask a moderator to remove if it absolutely necessary.', 403); } $originalPostInfo = $msz->forumCtx->posts->getPost(topicInfo: $postInfo->topicId); if($originalPostInfo->id === $postInfo->id) Template::displayInfo('This is the opening post of the topic it belongs to, it may not be deleted without deleting the entire topic as well.', 403); if($postRequestVerified && !$submissionConfirmed) { Tools::redirect($msz->urls->format('forum-post', ['post' => $postInfo->id])); break; } elseif(!$postRequestVerified) { Template::render('forum.confirm', [ 'title' => 'Confirm post deletion', 'class' => 'far fa-trash-alt', 'message' => sprintf('You are about to delete post #%d. Are you sure about that?', $postInfo->id), 'params' => [ 'p' => $postInfo->id, 'm' => 'delete', ], ]); break; } $msz->forumCtx->posts->deletePost($postInfo); $msz->createAuditLog('FORUM_POST_DELETE', [$postInfo->id]); Tools::redirect($msz->urls->format('forum-topic', ['topic' => $postInfo->topicId])); break; case 'nuke': if(!$canDeleteAny) Template::throwError(403); if($postRequestVerified && !$submissionConfirmed) { Tools::redirect($msz->urls->format('forum-post', ['post' => $postInfo->id])); break; } elseif(!$postRequestVerified) { Template::render('forum.confirm', [ 'title' => 'Confirm post nuke', 'class' => 'fas fa-radiation', 'message' => sprintf('You are about to PERMANENTLY DELETE post #%d. Are you sure about that?', $postInfo->id), 'params' => [ 'p' => $postInfo->id, 'm' => 'nuke', ], ]); break; } $msz->forumCtx->posts->nukePost($postInfo->id); $msz->createAuditLog('FORUM_POST_NUKE', [$postInfo->id]); Tools::redirect($msz->urls->format('forum-topic', ['topic' => $postInfo->topicId])); break; case 'restore': if(!$canDeleteAny) Template::throwError(403); if($postRequestVerified && !$submissionConfirmed) { Tools::redirect($msz->urls->format('forum-post', ['post' => $postInfo->id])); break; } elseif(!$postRequestVerified) { Template::render('forum.confirm', [ 'title' => 'Confirm post restore', 'class' => 'fas fa-magic', 'message' => sprintf('You are about to restore post #%d. Are you sure about that?', $postInfo->id), 'params' => [ 'p' => $postInfo->id, 'm' => 'restore', ], ]); break; } $msz->forumCtx->posts->restorePost($postInfo->id); $msz->createAuditLog('FORUM_POST_RESTORE', [$postInfo->id]); Tools::redirect($msz->urls->format('forum-topic', ['topic' => $postInfo->topicId])); break; default: // function as an alt for topic.php?p= by default Tools::redirect($msz->urls->format('forum-post', ['post' => $postInfo->id])); break; }