Mercurial > libervia-web
diff src/pages/tickets/page_meta.py @ 1078:296bda6b7ed0
pages (tickets): tickets discovery:
if not is not specified in URL, new discovery page is used.
Discovery is for now basic and allows only to use a free jid with standard node, or display nodes specified in config.
Service, node and name of a tickets node can be specified in config using tickets_trackers_json.
author | Goffi <goffi@goffi.org> |
---|---|
date | Mon, 26 Mar 2018 21:32:16 +0200 |
parents | d8666fdb015c |
children | ed67265205c4 |
line wrap: on
line diff
--- a/src/pages/tickets/page_meta.py Mon Mar 26 08:20:41 2018 +0200 +++ b/src/pages/tickets/page_meta.py Mon Mar 26 21:32:16 2018 +0200 @@ -2,48 +2,29 @@ # -*- 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' +name = u'tickets' access = C.PAGES_ACCESS_PUBLIC template = u"ticket/overview.html" def parse_url(self, request): - # check the service and node to use - try: - service = self.nextPath(request) - node = self.nextPath(request) - except IndexError: - log.warning(_(u"missing service and node")) - self.pageError(request, C.HTTP_BAD_REQUEST) - - if not service or service == u'@': - service = u'' + self.getPathArgs(request, ['service', 'node'], service='jid') + data = self.getRData(request) - if service: - try: - service = jid.JID(service) - except Exception: - log.warning(_(u"bad service entered: {}").format(service)) - self.pageError(request, C.HTTP_BAD_REQUEST) - - if not node or node == u'@': - node = u'' - - data = self.getRData(request) - data['service'] = service - data['node'] = node - + service, node = data[u'service'], data[u'node'] + if node is None: + self.pageRedirect(u"tickets_disco", request) + if node == u'@': + node = data[u'node'] = u'' template_data = request.template_data - template_data[u'url_tickets_list'] = self.getPageByName('tickets_list').getURL(service.full(), node or u'@') + template_data[u'url_tickets_list'] = self.getURL(service.full(), node or u'@') template_data[u'url_tickets_new'] = self.getSubPageURL(request, 'tickets_new') @defer.inlineCallbacks