view libervia/pages/blog/view/atom.xml/page_meta.py @ 1276:cad8f24e23d4

pages: use a coroutine for renderPage: renderPage is now a coroutine, and pages methods are launched using asDeferred, so they can be coroutines too. Full traceback is now logged for uncatched errors.
author Goffi <goffi@goffi.org>
date Fri, 19 Jun 2020 16:47:50 +0200
parents f511f8fbbf8a
children a20fe9eb307b
line wrap: on
line source

#!/usr/bin/env python3


from libervia.server.constants import Const as C
from twisted.internet import defer
from sat.tools.common import uri
import time

name = "blog_feed_atom"
access = C.PAGES_ACCESS_PUBLIC
template = "blog/atom.xml"


@defer.inlineCallbacks
def prepare_render(self, request):
    request.setHeader("Content-Type", "application/atom+xml; charset=utf-8")
    data = self.getRData(request)
    service, node = data["service"], data.get("node")
    self.checkCache(
        request, C.CACHE_PUBSUB, service=service, node=node, short="microblog"
    )
    data["show_comments"] = False
    template_data = request.template_data
    blog_page = self.getPageByName("blog_view")
    yield blog_page.prepare_render(self, request)
    items = data["items"]

    template_data["request_uri"] = self.host.getExtBaseURL(
        request, request.path.decode("utf-8")
    )
    template_data["xmpp_uri"] = uri.buildXMPPUri(
        "pubsub", subtype="microblog", path=service.full(), node=node
    )
    blog_view = self.getPageByName("blog_view")
    template_data["http_uri"] = self.host.getExtBaseURL(
        request, blog_view.getURL(service.full(), node)
    )
    if items:
        template_data["updated"] = items[0].updated
    else:
        template_data["updated"] = time.time()