diff src/pages/common/blog/atom.xml/page_meta.py @ 1017:8e7897b1008a

pages (blog/atom.xml, u/atom.xml): Atom feed implementation: - Content-Type is set to suitable value - common/blog is used, comments are disabled - request_uri, http_uri and xmpp_uri are set in template data - "updated" variable in template date is set with the "updated" value of first item (i.e. the most recent one), or to current time if there is not item yet. - u/atom.xml us a simple redirection to blog/atom.xml
author Goffi <goffi@goffi.org>
date Fri, 19 Jan 2018 18:14:28 +0100
parents
children 6dc90f109e57
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/pages/common/blog/atom.xml/page_meta.py	Fri Jan 19 18:14:28 2018 +0100
@@ -0,0 +1,35 @@
+#!/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')
+    template_data = request.template_data
+    data = self.getRData(request)
+    data['show_comments'] = False
+    service, node = data[u'service'], data.get(u'node')
+    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.uri.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()