changeset 1058:2290b6ec3991

pages (forums): first draft
author Goffi <goffi@goffi.org>
date Tue, 30 Jan 2018 08:15:04 +0100
parents 50ba8947a6e8
children d127a85b2fee
files src/pages/forums/list/page_meta.py src/pages/forums/topics/page_meta.py src/pages/forums/view/page_meta.py
diffstat 3 files changed, 154 insertions(+), 0 deletions(-) [+]
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/pages/forums/list/page_meta.py	Tue Jan 30 08:15:04 2018 +0100
@@ -0,0 +1,47 @@
+#!/usr/bin/env python2.7
+# -*- coding: utf-8 -*-
+
+from libervia.server.constants import Const as C
+from twisted.internet import defer
+from sat.core.log import getLogger
+from sat.tools.common import uri as xmpp_uri
+log = getLogger('pages/forum')
+import json
+"""forum handling pages"""
+
+name = u'forums'
+access = C.PAGES_ACCESS_PUBLIC
+template = u"forum/overview.html"
+
+def parse_url(self, request):
+    self.getPathArgs(request, ['service', 'node', 'forum_key'],
+                     service = u'@jid',
+                     node = u'@',
+                     forum_key = u'')
+
+def getLinks(self, forums):
+    for forum in forums:
+        try:
+            uri = forum['uri']
+        except KeyError:
+            pass
+        else:
+            uri = xmpp_uri.parseXMPPUri(uri)
+            service = uri[u'path']
+            node = uri[u'node']
+            forum['http_url'] = self.getPageByName(u'forum_topics').getURL(service, node)
+        if u'sub-forums' in forum:
+            getLinks(self, forum[u'sub-forums'])
+
+@defer.inlineCallbacks
+def prepare_render(self, request):
+    data = self.getRData(request)
+    template_data = request.template_data
+    service, node, key = data[u'service'], data[u'node'], data[u'forum_key']
+    profile = self.getProfile(request) or C.SERVICE_PROFILE
+
+    forums_raw = yield self.host.bridgeCall('forumsGet', service.full() if service else u'', node, key, profile)
+    forums = json.loads(forums_raw)
+    getLinks(self, forums)
+
+    template_data[u'forums'] = forums
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/pages/forums/topics/page_meta.py	Tue Jan 30 08:15:04 2018 +0100
@@ -0,0 +1,58 @@
+#!/usr/bin/env python2.7
+# -*- coding: utf-8 -*-
+
+from libervia.server.constants import Const as C
+from twisted.internet import defer
+from sat.core.i18n import _
+from sat.core.log import getLogger
+from sat.tools.common import uri as xmpp_uri
+log = getLogger('pages/forums/topics')
+
+name = u"forum_topics"
+access = C.PAGES_ACCESS_PUBLIC
+template = u"forum/view_topics.html"
+
+
+def parse_url(self, request):
+    self.getPathArgs(request, ['service', 'node'], 2,
+                     service = u'jid')
+
+
+@defer.inlineCallbacks
+def prepare_render(self, request):
+    profile = self.getProfile(request) or C.SERVICE_PROFILE
+    data = self.getRData(request)
+    service, node = data[u'service'], data[u'node']
+    request.template_data.update({u'service': service, u'node': node})
+    template_data = request.template_data
+    topics, metadata = yield self.host.bridgeCall(u'forumTopicsGet', service.full(), node, {}, profile)
+    template_data[u'identities'] = identities = {}
+    for topic in topics:
+        parsed_uri = xmpp_uri.parseXMPPUri(topic[u'uri'])
+        author = topic[u'author']
+        topic[u'http_uri'] = self.getPageByName(u'forum_view').getURL(parsed_uri[u'path'], parsed_uri[u'node'])
+        if author not in identities:
+            identities[topic[u'author']] = yield self.host.bridgeCall(u'identityGet', author, profile)
+    template_data[u'topics'] = topics
+
+@defer.inlineCallbacks
+def on_data_post(self, request):
+    profile = self.getProfile(request)
+    if profile is None:
+        self.pageError(request, C.HTTP_UNAUTHORIZED)
+    type_ = self.getPostedData(request, u'type')
+    if type_ == u'new_topic':
+        service, node, title, body = self.getPostedData(request, (u'service', u'node', u'title', u'body'))
+
+        if not title or not body:
+            self.pageError(request, C.HTTP_BAD_REQUEST)
+        topic_data = {u"title": title, u"content": body}
+        try:
+            yield self.host.bridgeCall(u'forumTopicCreate', service, node, topic_data, profile)
+        except Exception as e:
+            if u"forbidden" in unicode(e):
+                self.pageError(request, 401)
+            else:
+                raise e
+    else:
+        log.warning(_(u"Unhandled data type: {}").format(type_))
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/pages/forums/view/page_meta.py	Tue Jan 30 08:15:04 2018 +0100
@@ -0,0 +1,49 @@
+#!/usr/bin/env python2.7
+# -*- coding: utf-8 -*-
+
+from libervia.server.constants import Const as C
+from twisted.internet import defer
+from sat.core.i18n import _
+from sat.core.log import getLogger
+log = getLogger('pages/forums/view')
+
+name = u"forum_view"
+access = C.PAGES_ACCESS_PUBLIC
+template = u"forum/view.html"
+
+
+def parse_url(self, request):
+    self.getPathArgs(request, ['service', 'node'], 2,
+                     service = u'jid')
+
+@defer.inlineCallbacks
+def prepare_render(self, request):
+    data = self.getRData(request)
+    data['show_comments'] = False
+    blog_page = self.getPageByName(u'blog')
+    request.args['before'] = ['']
+    request.args['reverse'] = ['1']
+    yield blog_page.prepare_render(self, request)
+    request.template_data[u'login_url'] = self.getPageRedirectURL(request)
+
+@defer.inlineCallbacks
+def on_data_post(self, request):
+    profile = self.getProfile(request)
+    if profile is None:
+        self.pageError(request, C.HTTP_UNAUTHORIZED)
+    type_ = self.getPostedData(request, u'type')
+    if type_ == u'comment':
+        service, node, body = self.getPostedData(request, (u'service', u'node', u'body'))
+
+        if not body:
+            self.pageError(request, C.HTTP_BAD_REQUEST)
+        mb_data = {u"content": body}
+        try:
+            yield self.host.bridgeCall(u'mbSend', service, node, mb_data, profile)
+        except Exception as e:
+            if u"forbidden" in unicode(e):
+                self.pageError(request, 401)
+            else:
+                raise e
+    else:
+        log.warning(_(u"Unhandled data type: {}").format(type_))