Mercurial > libervia-web
view libervia/pages/forums/view/page_meta.py @ 1387:a84383c659b4
lists: creation, invitation, item deletion:
this big patch includes:
- reorganisation of pages for consistency, discovery is now the main list page, and list
overview is now in `view` while item view is moved to `view_item`
- lists from lists of interest are now shown in discovery page
- list deletion from discory page
- list can now be created, using templates now available from backend
- invitation manager can now be used from list overview
- list item can now be deleted from `view_item`
author | Goffi <goffi@goffi.org> |
---|---|
date | Sat, 20 Feb 2021 14:07:22 +0100 |
parents | f511f8fbbf8a |
children | 4cf2b73e63aa |
line wrap: on
line source
#!/usr/bin/env python3 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 data_format log = getLogger(__name__) name = "forum_view" access = C.PAGES_ACCESS_PUBLIC template = "forum/view.html" def parse_url(self, request): self.getPathArgs(request, ["service", "node"], 2, service="jid") @defer.inlineCallbacks def prepare_render(self, request): data = self.getRData(request) data["show_comments"] = False blog_page = self.getPageByName("blog_view") request.args[b"before"] = [b""] request.args[b"reverse"] = [b"1"] yield blog_page.prepare_render(self, request) request.template_data["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_FORBIDDEN) type_ = self.getPostedData(request, "type") if type_ == "comment": service, node, body = self.getPostedData(request, ("service", "node", "body")) if not body: self.pageError(request, C.HTTP_BAD_REQUEST) mb_data = {"content": body} try: yield self.host.bridgeCall( "mbSend", service, node, data_format.serialise(mb_data), profile) except Exception as e: if "forbidden" in str(e): self.pageError(request, 401) else: raise e else: log.warning(_("Unhandled data type: {}").format(type_))