Mercurial > libervia-web
annotate src/pages/common/blog/page_meta.py @ 1011:fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
author | Goffi <goffi@goffi.org> |
---|---|
date | Fri, 12 Jan 2018 22:04:33 +0100 |
parents | d821c112e656 |
children | fc1c913cc9d1 |
rev | line source |
---|---|
928
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
1 #!/usr/bin/env python2.7 |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
2 # -*- coding: utf-8 -*- |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
3 from libervia.server.constants import Const as C |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
4 from twisted.words.protocols.jabber import jid |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
5 from twisted.internet import defer |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
6 from sat.tools.common import data_objects |
947
92f0eeb6dc72
pages: cache identities identities in session + get identities for comments in blog
Goffi <goffi@goffi.org>
parents:
939
diff
changeset
|
7 from libervia.server import session_iface |
928
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
8 from sat.core.i18n import _ |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
9 from sat.core.log import getLogger |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
10 import urllib |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
11 log = getLogger('pages/common/blog') |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
12 |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
13 """generic blog (with service/node provided)""" |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
14 name = u'blog' |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
15 template = u"blog/articles.html" |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
16 uri_handlers = {(u'pubsub', u'microblog'): 'microblog_uri'} |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
17 |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
18 |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
19 def microblog_uri(self, uri_data): |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
20 service = urllib.quote_plus(uri_data[u'path']) |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
21 node = urllib.quote_plus(uri_data[u'node']) |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
22 return service + u'/' + node |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
23 |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
24 |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
25 def parse_url(self, request): |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
26 """URL is /[service]/[node] |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
27 |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
28 if [node] is not found, default namespace is used |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
29 if both [service] and [node] are not found, default service is used too |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
30 """ |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
31 data = self.getRData(request) |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
32 |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
33 try: |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
34 service = self.nextPath(request) |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
35 except IndexError: |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
36 data['service'] = u'' |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
37 else: |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
38 try: |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
39 data[u"service"] = jid.JID(service) |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
40 except Exception: |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
41 log.warning(_(u"bad service entered: {}").format(service)) |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
42 self.pageError(request, C.HTTP_BAD_REQUEST) |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
43 |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
44 try: |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
45 data['node'] = self.nextPath(request) |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
46 except IndexError: |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
47 data['node'] = u'' |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
48 |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
49 |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
50 @defer.inlineCallbacks |
947
92f0eeb6dc72
pages: cache identities identities in session + get identities for comments in blog
Goffi <goffi@goffi.org>
parents:
939
diff
changeset
|
51 def appendComments(self, blog_items, identities, profile): |
932
af6a62e21053
pages (common/blog): new show_comments variable is used in session data, if True comments are grabbed and chained to items
Goffi <goffi@goffi.org>
parents:
928
diff
changeset
|
52 for blog_item in blog_items: |
947
92f0eeb6dc72
pages: cache identities identities in session + get identities for comments in blog
Goffi <goffi@goffi.org>
parents:
939
diff
changeset
|
53 if identities is not None: |
92f0eeb6dc72
pages: cache identities identities in session + get identities for comments in blog
Goffi <goffi@goffi.org>
parents:
939
diff
changeset
|
54 author = blog_item.author_jid |
92f0eeb6dc72
pages: cache identities identities in session + get identities for comments in blog
Goffi <goffi@goffi.org>
parents:
939
diff
changeset
|
55 if author not in identities: |
996
d821c112e656
pages (chat): implementation of chat page using new dynamic pages, first draft
Goffi <goffi@goffi.org>
parents:
949
diff
changeset
|
56 identities[author] = yield self.host.bridgeCall(u'identityGet', author, profile) |
932
af6a62e21053
pages (common/blog): new show_comments variable is used in session data, if True comments are grabbed and chained to items
Goffi <goffi@goffi.org>
parents:
928
diff
changeset
|
57 for comment_data in blog_item.comments: |
af6a62e21053
pages (common/blog): new show_comments variable is used in session data, if True comments are grabbed and chained to items
Goffi <goffi@goffi.org>
parents:
928
diff
changeset
|
58 service = comment_data[u'service'] |
af6a62e21053
pages (common/blog): new show_comments variable is used in session data, if True comments are grabbed and chained to items
Goffi <goffi@goffi.org>
parents:
928
diff
changeset
|
59 node = comment_data[u'node'] |
948
c20ac29d869f
pages (common/blog): don't fail if an error is raised while getting comment
Goffi <goffi@goffi.org>
parents:
947
diff
changeset
|
60 try: |
c20ac29d869f
pages (common/blog): don't fail if an error is raised while getting comment
Goffi <goffi@goffi.org>
parents:
947
diff
changeset
|
61 comments_data = yield self.host.bridge.mbGet( |
c20ac29d869f
pages (common/blog): don't fail if an error is raised while getting comment
Goffi <goffi@goffi.org>
parents:
947
diff
changeset
|
62 service, |
c20ac29d869f
pages (common/blog): don't fail if an error is raised while getting comment
Goffi <goffi@goffi.org>
parents:
947
diff
changeset
|
63 node, |
c20ac29d869f
pages (common/blog): don't fail if an error is raised while getting comment
Goffi <goffi@goffi.org>
parents:
947
diff
changeset
|
64 C.NO_LIMIT, |
c20ac29d869f
pages (common/blog): don't fail if an error is raised while getting comment
Goffi <goffi@goffi.org>
parents:
947
diff
changeset
|
65 [], |
c20ac29d869f
pages (common/blog): don't fail if an error is raised while getting comment
Goffi <goffi@goffi.org>
parents:
947
diff
changeset
|
66 {}, |
c20ac29d869f
pages (common/blog): don't fail if an error is raised while getting comment
Goffi <goffi@goffi.org>
parents:
947
diff
changeset
|
67 profile) |
c20ac29d869f
pages (common/blog): don't fail if an error is raised while getting comment
Goffi <goffi@goffi.org>
parents:
947
diff
changeset
|
68 except Exception as e: |
c20ac29d869f
pages (common/blog): don't fail if an error is raised while getting comment
Goffi <goffi@goffi.org>
parents:
947
diff
changeset
|
69 log.warning(_(u"Can't get comments at {node} (service: {service}): {msg}").format( |
c20ac29d869f
pages (common/blog): don't fail if an error is raised while getting comment
Goffi <goffi@goffi.org>
parents:
947
diff
changeset
|
70 service=service, |
c20ac29d869f
pages (common/blog): don't fail if an error is raised while getting comment
Goffi <goffi@goffi.org>
parents:
947
diff
changeset
|
71 node=node, |
c20ac29d869f
pages (common/blog): don't fail if an error is raised while getting comment
Goffi <goffi@goffi.org>
parents:
947
diff
changeset
|
72 msg=e)) |
c20ac29d869f
pages (common/blog): don't fail if an error is raised while getting comment
Goffi <goffi@goffi.org>
parents:
947
diff
changeset
|
73 continue |
c20ac29d869f
pages (common/blog): don't fail if an error is raised while getting comment
Goffi <goffi@goffi.org>
parents:
947
diff
changeset
|
74 |
932
af6a62e21053
pages (common/blog): new show_comments variable is used in session data, if True comments are grabbed and chained to items
Goffi <goffi@goffi.org>
parents:
928
diff
changeset
|
75 comments = data_objects.BlogItems(comments_data) |
af6a62e21053
pages (common/blog): new show_comments variable is used in session data, if True comments are grabbed and chained to items
Goffi <goffi@goffi.org>
parents:
928
diff
changeset
|
76 blog_item.appendCommentsItems(comments) |
947
92f0eeb6dc72
pages: cache identities identities in session + get identities for comments in blog
Goffi <goffi@goffi.org>
parents:
939
diff
changeset
|
77 yield appendComments(self, comments, identities, profile) |
932
af6a62e21053
pages (common/blog): new show_comments variable is used in session data, if True comments are grabbed and chained to items
Goffi <goffi@goffi.org>
parents:
928
diff
changeset
|
78 |
1011
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
79 @defer.inlineCallbacks |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
80 def getBlogData(self, request, service, node, extra, profile): |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
81 try: |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
82 blog_data = yield self.host.bridge.mbGet( |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
83 service.userhost(), |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
84 node, |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
85 C.NO_LIMIT, |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
86 [], |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
87 extra, |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
88 profile) |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
89 except Exception as e: |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
90 # FIXME: need a better way to test errors in bridge errback |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
91 if u"forbidden" in unicode(e): |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
92 self.pageError(request, 401) |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
93 else: |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
94 raise e |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
95 |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
96 items = data_objects.BlogItems(blog_data) |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
97 defer.returnValue((blog_data, items)) |
932
af6a62e21053
pages (common/blog): new show_comments variable is used in session data, if True comments are grabbed and chained to items
Goffi <goffi@goffi.org>
parents:
928
diff
changeset
|
98 |
af6a62e21053
pages (common/blog): new show_comments variable is used in session data, if True comments are grabbed and chained to items
Goffi <goffi@goffi.org>
parents:
928
diff
changeset
|
99 @defer.inlineCallbacks |
928
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
100 def prepare_render(self, request): |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
101 data = self.getRData(request) |
932
af6a62e21053
pages (common/blog): new show_comments variable is used in session data, if True comments are grabbed and chained to items
Goffi <goffi@goffi.org>
parents:
928
diff
changeset
|
102 # if the comments are not explicitly hidden, we show them |
af6a62e21053
pages (common/blog): new show_comments variable is used in session data, if True comments are grabbed and chained to items
Goffi <goffi@goffi.org>
parents:
928
diff
changeset
|
103 service, node, show_comments = data.get(u'service', u''), data.get(u'node', u''), data.get(u'show_comments', True) |
928
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
104 profile = self.getProfile(request) |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
105 if profile is None: |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
106 profile = C.SERVICE_PROFILE |
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
107 |
1011
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
108 params = self.getAllPostedData(request, multiple=False) |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
109 extra = {u'rsm_max': u'10'} |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
110 if u'after' in params: |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
111 extra[u'rsm_after'] = params[u'after'] |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
112 elif u'before' in params: |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
113 extra[u'rsm_before'] = params[u'before'] |
928
ee243d48100e
pages (common): added common hierarchy for reusable pages (blog is the first)
Goffi <goffi@goffi.org>
parents:
diff
changeset
|
114 |
1011
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
115 blog_data, items = yield getBlogData(self, request, service, node, extra, profile) |
947
92f0eeb6dc72
pages: cache identities identities in session + get identities for comments in blog
Goffi <goffi@goffi.org>
parents:
939
diff
changeset
|
116 template_data = request.template_data |
1011
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
117 if items: |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
118 last_id = items[-1].id |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
119 template_data['older_url'] = self.getParamURL(request, after=last_id) |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
120 if u'before' in params or u'after' in params: |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
121 first_id = items[0].id |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
122 template_data['newer_url'] = self.getParamURL(request, before=first_id) |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
123 else: |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
124 # no items, we have requested items before last post, or blog is empty |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
125 extra = {u'rsm_max': u'10'} |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
126 blog_data, items = yield getBlogData(self, request, service, node, extra, profile) |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
127 if items: |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
128 last_id = items[-1].id |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
129 template_data['older_url'] = self.getParamURL(request, after=last_id) |
fe08a5c95b27
pages (blog): added pagination using RSM and blog now fill older_url and newer_url in template_data
Goffi <goffi@goffi.org>
parents:
996
diff
changeset
|
130 |
947
92f0eeb6dc72
pages: cache identities identities in session + get identities for comments in blog
Goffi <goffi@goffi.org>
parents:
939
diff
changeset
|
131 identities = template_data[u'identities'] = self.host.getSessionData(request, session_iface.ISATSession).identities |
932
af6a62e21053
pages (common/blog): new show_comments variable is used in session data, if True comments are grabbed and chained to items
Goffi <goffi@goffi.org>
parents:
928
diff
changeset
|
132 |
af6a62e21053
pages (common/blog): new show_comments variable is used in session data, if True comments are grabbed and chained to items
Goffi <goffi@goffi.org>
parents:
928
diff
changeset
|
133 if show_comments: |
947
92f0eeb6dc72
pages: cache identities identities in session + get identities for comments in blog
Goffi <goffi@goffi.org>
parents:
939
diff
changeset
|
134 yield appendComments(self, items, identities, profile) |
932
af6a62e21053
pages (common/blog): new show_comments variable is used in session data, if True comments are grabbed and chained to items
Goffi <goffi@goffi.org>
parents:
928
diff
changeset
|
135 |
af6a62e21053
pages (common/blog): new show_comments variable is used in session data, if True comments are grabbed and chained to items
Goffi <goffi@goffi.org>
parents:
928
diff
changeset
|
136 template_data[u'items'] = items |
949
36e9747520fd
pages (common/blog): use request data to indicate if comments are allowed
Goffi <goffi@goffi.org>
parents:
948
diff
changeset
|
137 template_data[u'allow_commenting'] = data.get(u'allow_commenting', False) |
933
e4c13a995e0b
pages (common/blog): data post (i.e. new comments) is now handled
Goffi <goffi@goffi.org>
parents:
932
diff
changeset
|
138 |
e4c13a995e0b
pages (common/blog): data post (i.e. new comments) is now handled
Goffi <goffi@goffi.org>
parents:
932
diff
changeset
|
139 |
e4c13a995e0b
pages (common/blog): data post (i.e. new comments) is now handled
Goffi <goffi@goffi.org>
parents:
932
diff
changeset
|
140 @defer.inlineCallbacks |
e4c13a995e0b
pages (common/blog): data post (i.e. new comments) is now handled
Goffi <goffi@goffi.org>
parents:
932
diff
changeset
|
141 def on_data_post(self, request): |
e4c13a995e0b
pages (common/blog): data post (i.e. new comments) is now handled
Goffi <goffi@goffi.org>
parents:
932
diff
changeset
|
142 profile = self.getProfile(request) |
e4c13a995e0b
pages (common/blog): data post (i.e. new comments) is now handled
Goffi <goffi@goffi.org>
parents:
932
diff
changeset
|
143 if profile is None: |
e4c13a995e0b
pages (common/blog): data post (i.e. new comments) is now handled
Goffi <goffi@goffi.org>
parents:
932
diff
changeset
|
144 self.pageError(request, C.HTTP_UNAUTHORIZED) |
939
1375b96f4309
pages (common/blog): check posted data type for comments
Goffi <goffi@goffi.org>
parents:
933
diff
changeset
|
145 type_ = self.getPostedData(request, u'type') |
1375b96f4309
pages (common/blog): check posted data type for comments
Goffi <goffi@goffi.org>
parents:
933
diff
changeset
|
146 if type_ == u'comment': |
1375b96f4309
pages (common/blog): check posted data type for comments
Goffi <goffi@goffi.org>
parents:
933
diff
changeset
|
147 service, node, body = self.getPostedData(request, (u'service', u'node', u'body')) |
1375b96f4309
pages (common/blog): check posted data type for comments
Goffi <goffi@goffi.org>
parents:
933
diff
changeset
|
148 |
1375b96f4309
pages (common/blog): check posted data type for comments
Goffi <goffi@goffi.org>
parents:
933
diff
changeset
|
149 if not body: |
1375b96f4309
pages (common/blog): check posted data type for comments
Goffi <goffi@goffi.org>
parents:
933
diff
changeset
|
150 self.pageError(request, C.HTTP_BAD_REQUEST) |
1375b96f4309
pages (common/blog): check posted data type for comments
Goffi <goffi@goffi.org>
parents:
933
diff
changeset
|
151 comment_data = {u"content": body} |
1375b96f4309
pages (common/blog): check posted data type for comments
Goffi <goffi@goffi.org>
parents:
933
diff
changeset
|
152 try: |
1375b96f4309
pages (common/blog): check posted data type for comments
Goffi <goffi@goffi.org>
parents:
933
diff
changeset
|
153 yield self.host.bridge.mbSend(service, node, comment_data, profile) |
1375b96f4309
pages (common/blog): check posted data type for comments
Goffi <goffi@goffi.org>
parents:
933
diff
changeset
|
154 except Exception as e: |
1375b96f4309
pages (common/blog): check posted data type for comments
Goffi <goffi@goffi.org>
parents:
933
diff
changeset
|
155 if u"forbidden" in unicode(e): |
1375b96f4309
pages (common/blog): check posted data type for comments
Goffi <goffi@goffi.org>
parents:
933
diff
changeset
|
156 self.pageError(request, 401) |
1375b96f4309
pages (common/blog): check posted data type for comments
Goffi <goffi@goffi.org>
parents:
933
diff
changeset
|
157 else: |
1375b96f4309
pages (common/blog): check posted data type for comments
Goffi <goffi@goffi.org>
parents:
933
diff
changeset
|
158 raise e |
1375b96f4309
pages (common/blog): check posted data type for comments
Goffi <goffi@goffi.org>
parents:
933
diff
changeset
|
159 else: |
1375b96f4309
pages (common/blog): check posted data type for comments
Goffi <goffi@goffi.org>
parents:
933
diff
changeset
|
160 log.warning(_(u"Unhandled data type: {}").format(type_)) |