diff libervia/web/pages/merge-requests/disco/page_meta.py @ 1518:eb00d593801d

refactoring: rename `libervia` to `libervia.web` + update imports following backend changes
author Goffi <goffi@goffi.org>
date Fri, 02 Jun 2023 16:49:28 +0200
parents libervia/pages/merge-requests/disco/page_meta.py@106bae41f5c8
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/libervia/web/pages/merge-requests/disco/page_meta.py	Fri Jun 02 16:49:28 2023 +0200
@@ -0,0 +1,41 @@
+#!/usr/bin/env python3
+
+
+from libervia.web.server.constants import Const as C
+from twisted.words.protocols.jabber import jid
+from libervia.backend.core.log import getLogger
+
+log = getLogger(__name__)
+
+
+name = "merge-requests_disco"
+access = C.PAGES_ACCESS_PUBLIC
+template = "merge-request/discover.html"
+
+
+def prepare_render(self, request):
+    mr_handlers_config = self.host.options["mr_handlers_json"]
+    if mr_handlers_config:
+        handlers = request.template_data["mr_handlers"] = []
+        try:
+            for handler_data in mr_handlers_config:
+                service = handler_data["service"]
+                node = handler_data["node"]
+                name = handler_data["name"]
+                url = self.get_page_by_name("merge-requests").get_url(service, node)
+                handlers.append({"name": name, "url": url})
+        except KeyError as e:
+            log.warning("Missing field in mr_handlers_json: {msg}".format(msg=e))
+        except Exception as e:
+            log.warning("Can't decode mr handlers: {msg}".format(msg=e))
+
+
+def on_data_post(self, request):
+    jid_str = self.get_posted_data(request, "jid")
+    try:
+        jid_ = jid.JID(jid_str)
+    except RuntimeError:
+        self.page_error(request, C.HTTP_BAD_REQUEST)
+    # for now we just use default node
+    url = self.get_page_by_name("merge-requests").get_url(jid_.full(), "@")
+    self.http_redirect(request, url)