view src/pages/common/blog/atom.xml/page_meta.py @ 1050:6c98c0baa038

pages (common/blog/atom.xml): don't use query elements in request_uri: when used in self link, some search engine bots (google bot at least) are trying to retrieve page with "comments_max" query argument, which is then returned in the feed in self link, and it get added in a infinite loop.
author Goffi <goffi@goffi.org>
date Thu, 25 Jan 2018 08:17:29 +0100
parents 6dc90f109e57
children
line wrap: on
line source

#!/usr/bin/env python2.7
# -*- coding: utf-8 -*-

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

name = u"blog_feed_atom"
access = C.PAGES_ACCESS_PUBLIC
template = u"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[u'service'], data.get(u'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(u'blog')
    yield blog_page.prepare_render(self, request)
    items = data[u'items']

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