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