diff options
author | Jonas Kohl | 2024-12-22 12:45:07 +0100 |
---|---|---|
committer | Jonas Kohl | 2024-12-22 12:45:07 +0100 |
commit | bf15bdf4639c61d9855cc76b4e58463eabbd6760 (patch) | |
tree | e6719db30ddd4ac3eb33e29953b3b48f0f4284bf /src/application/actions/editpost | |
parent | c4fb88b882e00692a28cabd677cacfc1e50f86d4 (diff) |
Add missing 'editpost' actionv0.6.3
Diffstat (limited to 'src/application/actions/editpost')
-rw-r--r-- | src/application/actions/editpost/post.php | 58 |
1 files changed, 58 insertions, 0 deletions
diff --git a/src/application/actions/editpost/post.php b/src/application/actions/editpost/post.php new file mode 100644 index 0000000..1ea83a7 --- /dev/null +++ b/src/application/actions/editpost/post.php @@ -0,0 +1,58 @@ +<?php + +use mystic\forum\orm\Post; +use mystic\forum\orm\Topic; +use mystic\forum\orm\User; +use mystic\forum\orm\UserPermissions; +use mystic\forum\utils\RequestUtils; + +if (!$currentUser) { + http_response_code(403); + msg_error(__("You need to be logged in to edit posts!")); + exit; +} + +$formId = "editpost"; +$postId = RequestUtils::getRequiredField("post", $formId); + +$item = new Post(); +$item->id = $postId; + +if (!$db->fetch($item) || $item->deleted) { + http_response_code(404); + msg_error(__("No post exists with this id")); + exit; +} + +$topicAuthor = new User(); +$topicAuthor->id = $item->authorId; + +if (!$db->fetch($topicAuthor)) + $topicAuthor = null; + +$canEdit = ($currentUser->id === $topicAuthor?->id && $topicAuthor?->hasPermission(UserPermissions::EDIT_OWN_POST)) + || ($currentUser->hasPermission(UserPermissions::EDIT_OTHER_POST)); + +$topic = new Topic(); +$topic->id = $item->topicId; + +if (!$db->fetch($topic)) + $topic = null; + +if ($topic->isLocked) { + http_response_code(403); + msg_error(__("This topic has been locked")); + exit; +} + +if (!$canEdit) { + http_response_code(403); + msg_error(__("You don't have permission to edit this post")); + exit; +} + +render("edit_post.twig", [ + "post" => $item, + "topicAuthor" => $topicAuthor, + "topic" => $topic, +]); |