view libervia/web/pages/merge-requests/disco/page_meta.py @ 1610:19c83dd943df

browser (chat): don't set `None` value in message data used in template: `None` can behave unexpectedly with template, unsetting the value is safer.
author Goffi <goffi@goffi.org>
date Wed, 12 Jun 2024 23:09:12 +0200
parents eb00d593801d
children
line wrap: on
line source

#!/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)