# HG changeset patch # User Goffi # Date 1509916283 -3600 # Node ID 4d1dcf97740f54c549f77e38e6635fa961acf771 # Parent 12c1491711998ce283b6a83417174ae3bea1fbd3 pages (tickets): tickets first draft: following pages are available: tickets/[service]/[node]: display list of all tickets ([node] can be "@" for default node) .../new: create a ticket .../view: view a single ticket and its comments, and allow to publish a new comment if use is logged in. diff -r 12c149171199 -r 4d1dcf97740f src/pages/tickets/new/page_meta.py --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/pages/tickets/new/page_meta.py Sun Nov 05 22:11:23 2017 +0100 @@ -0,0 +1,40 @@ +#!/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 template_xmlui +from sat.core.log import getLogger +log = getLogger('pages/ticket') +import urllib +"""ticket handling pages""" + +access = C.PAGES_ACCESS_PROFILE +template = u"ticket/create.html" + + +@defer.inlineCallbacks +def prepare_render(self, request): + data = self.getRData(request) + service, node = data.get(u'service', u''), data.get(u'node', u'') + profile = self.getProfile(request) + schema = yield self.host.bridge.ticketsSchemaGet(service.full(), node, profile) + data['schema'] = schema + # following fields are handled in backend + ignore = ('reporter', 'created', 'updated', 'comments_uri') + xmlui_obj = template_xmlui.create(self.host, schema, ignore=ignore) + request.template_data[u'new_ticket_xmlui'] = xmlui_obj + +@defer.inlineCallbacks +def on_data_post(self, request): + data = self.getRData(request) + service = data['service'] + node = data['node'] + posted_data = self.getAllPostedData(request) + profile = self.getProfile(request) + yield self.host.bridge.ticketsSet(service.full(), node, posted_data, u'', u'', {}, profile) + # we don't want to redirect to creation page on success, but to tickets list + data['post_redirect_uri'] = u'{list_url}/{service}/{node}'.format( + service = urllib.quote_plus(service.full().encode('utf-8')), + node = urllib.quote_plus(node.encode('utf-8')) if node else u'@', + list_url = self.getPageByName(u'tickets_list').url) diff -r 12c149171199 -r 4d1dcf97740f src/pages/tickets/page_meta.py --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/pages/tickets/page_meta.py Sun Nov 05 22:11:23 2017 +0100 @@ -0,0 +1,60 @@ +#!/usr/bin/env python2.7 +# -*- coding: utf-8 -*- + +from libervia.server.constants import Const as C +from sat.core.i18n import _ +from twisted.internet import defer +from twisted.words.protocols.jabber import jid +from sat.tools.common import template_xmlui +from sat.tools.common import data_objects +from sat.core.log import getLogger +log = getLogger('pages/ticket') +"""ticket handling pages""" + +name = u'tickets_list' +access = C.PAGES_ACCESS_PUBLIC +template = u"ticket/overview.html" +trailing_slash = True + + +def parse_url(self, request): + try: + service = self.nextPath(request) + except IndexError: + service = u'' + else: + if not service or service == u'@': + service = u'' + + if service: + try: + service = jid.JID(service) + except Exception: + log.warning(_(u"bad service entered: {}").format(service)) + self.pageError(request, C.HTTP_BAD_REQUEST) + + try: + node = self.nextPath(request) + except IndexError: + node = u'' + else: + if not node or node == u'@': + node = u'' + + data = self.getRData(request) + + data['service'] = service + data['node'] = node + + +@defer.inlineCallbacks +def prepare_render(self, request): + data = self.getRData(request) + template_data = request.template_data + service, node = data.get(u'service', u''), data.get(u'node', u'') + profile = self.getProfile(request) or C.SERVICE_PROFILE + + tickets = yield self.host.bridge.ticketsGet(service.full() if service else u'', node, C.NO_LIMIT, [], '', {}, profile) + tickets = [template_xmlui.create(self.host, x) for x in tickets[0]] + template_data[u'tickets'] = tickets + template_data[u'on_ticket_click'] = data_objects.OnClick(url="view/{item.id}") diff -r 12c149171199 -r 4d1dcf97740f src/pages/tickets/view/page_meta.py --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/pages/tickets/view/page_meta.py Sun Nov 05 22:11:23 2017 +0100 @@ -0,0 +1,65 @@ +#!/usr/bin/env python2.7 +# -*- coding: utf-8 -*- + +from libervia.server.constants import Const as C +from sat.core.i18n import _ +from twisted.internet import defer +from sat.tools.common import template_xmlui +from sat.tools.common import uri +from sat.tools.common import data_objects +from sat.core.log import getLogger +log = getLogger('pages/tickets/view') +"""ticket handling pages""" + +access = C.PAGES_ACCESS_PUBLIC +template = u"ticket/item.html" + + +def parse_url(self, request): + try: + item_id = self.nextPath(request) + except IndexError: + log.warning(_(u"no ticket id specified")) + self.pageError(request, C.HTTP_BAD_REQUEST) + + data = self.getRData(request) + data[u'ticket_id'] = item_id + +@defer.inlineCallbacks +def prepare_render(self, request): + data = self.getRData(request) + template_data = request.template_data + service, node, ticket_id = data.get(u'service', u''), data.get(u'node', u''), data[u'ticket_id'] + profile = self.getProfile(request) + + if profile is None: + profile = C.SERVICE_PROFILE + else: + template_data['profile'] = profile + + tickets = yield self.host.bridge.ticketsGet(service.full() if service else u'', node, C.NO_LIMIT, [ticket_id], '', {}, profile) + ticket = [template_xmlui.create(self.host, x) for x in tickets[0]][0] + template_data[u'item'] = ticket + comments_uri = ticket.widgets['comments_uri'].value + if comments_uri: + uri_data = uri.parseXMPPUri(comments_uri) + template_data['comments_node'] = comments_node = uri_data['node'] + template_data['comments_service'] = comments_service = uri_data['path'] + comments = yield self.host.bridge.mbGet(comments_service, + comments_node, + C.NO_LIMIT, + [], + {}, + profile) + + template_data[u'comments'] = data_objects.BlogItems(comments) + template_data[u'login_url'] = self.getPageRedirectURL(request) + +@defer.inlineCallbacks +def on_data_post(self, request): + type_ = self.getPostedData(request, u'type') + if type_ == u'comment': + blog_page = self.getPageByName(u'blog') + yield blog_page.on_data_post(self, request) + else: + log.warning(_(u"Unhandled data type: {}").format(type_))