139 lines
5.3 KiB
PHP
139 lines
5.3 KiB
PHP
<?php
|
|
namespace Misuzu;
|
|
|
|
use RuntimeException;
|
|
|
|
if(!isset($msz) || !($msz instanceof \Misuzu\MisuzuContext))
|
|
die('Script must be called through the Misuzu route dispatcher.');
|
|
|
|
$postId = !empty($_GET['p']) && is_string($_GET['p']) ? (string)$_GET['p'] : '0';
|
|
$postMode = !empty($_GET['m']) && is_string($_GET['m']) ? (string)$_GET['m'] : '';
|
|
$submissionConfirmed = !empty($_GET['confirm']) && is_string($_GET['confirm']) && $_GET['confirm'] === '1';
|
|
|
|
$postRequestVerified = CSRF::validateRequest();
|
|
|
|
if(!empty($postMode) && !$msz->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;
|
|
}
|