[somebot] /mod-get-post-text <post-permalink>
authorSomeone <someone@somenet.org>
Wed, 8 Dec 2021 18:38:38 +0000 (19:38 +0100)
committerSomeone <someone@somenet.org>
Wed, 8 Dec 2021 18:38:38 +0000 (19:38 +0100)
modules/CACommandModGetPostText.py [new file with mode: 0644]

diff --git a/modules/CACommandModGetPostText.py b/modules/CACommandModGetPostText.py
new file mode 100644 (file)
index 0000000..78c8df1
--- /dev/null
@@ -0,0 +1,45 @@
+# Mattermost Bot module.
+#  Copyright (c) 2016-2021 by Someone <someone@somenet.org> (aka. Jan Vales <jan@jvales.net>)
+#  published under MIT-License
+#
+# This command relies on the priviledged DB-Cleaner maint script.
+
+
+
+from AbstractCommand import AbstractCommand
+class CACommandModGetPostText(AbstractCommand):
+    TRIGGER = "mod-get-post-text"
+    CONFIG = {"display_name": "somebot-command", "auto_complete": True,
+              "auto_complete_hint": "<permalink>",
+             }
+    CONFIG["auto_complete_desc"] = CONFIG["description"] = "Get post-text removed by /mod-remove-post-text. Run in same channel. [CHANNEL_ADMIN]"
+
+
+    def on_POST(self, request, data):
+        self._require_channel_admin(data) # will throw an exception if not. (Dont try-except: Its handled up the stack.)
+
+        msg_text = data['text'].strip()
+
+        try:
+            splitpath = msg_text.strip().strip("/").split("/")
+            if splitpath[4] == "pl":
+                pl_post_id = splitpath[5]
+        except:
+            request.cmd_respond_text_temp("``/"+self.TRIGGER+"`` failed: The parameter is not a valid post-permalink. :(")
+            return
+
+        post = self.bot.api.get_post(pl_post_id, exc=False)
+
+        if "status_code" in post and post["status_code"] == 404:
+            request.cmd_respond_text_temp("``/"+self.TRIGGER+"`` failed: The perma-linked post doesnt seem to exist. Was it deleted?")
+            return
+
+        if post["channel_id"] != data["channel_id"]:
+            request.cmd_respond_text_temp("``/"+self.TRIGGER+"`` failed: Must be executed in the same channel as the post. :(")
+            return
+
+        if "somebot_removed_post_text" not in post["props"]:
+            request.cmd_respond_text_temp("``/"+self.TRIGGER+"`` failed: The post has no known removed text. :(")
+            return
+
+        request.cmd_respond_text_temp("### ``Stored removed post-text``\n\n----\n\n"+post["props"]["somebot_removed_post_text"])