summaryrefslogtreecommitdiff
path: root/src/application/actions
diff options
context:
space:
mode:
Diffstat (limited to 'src/application/actions')
-rw-r--r--src/application/actions/editpost/post.php58
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,
+]);