Mercurial > libervia-web
comparison 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 |
comparison
equal
deleted
inserted
replaced
1077:880ea673aaff | 1078:296bda6b7ed0 |
---|---|
1 #!/usr/bin/env python2.7 | 1 #!/usr/bin/env python2.7 |
2 # -*- coding: utf-8 -*- | 2 # -*- coding: utf-8 -*- |
3 | 3 |
4 from libervia.server.constants import Const as C | 4 from libervia.server.constants import Const as C |
5 from sat.core.i18n import _ | |
6 from twisted.internet import defer | 5 from twisted.internet import defer |
7 from twisted.words.protocols.jabber import jid | |
8 from sat.tools.common import template_xmlui | 6 from sat.tools.common import template_xmlui |
9 from sat.tools.common import data_objects | 7 from sat.tools.common import data_objects |
10 from sat.core.log import getLogger | 8 from sat.core.log import getLogger |
11 log = getLogger('pages/ticket') | 9 log = getLogger('pages/ticket') |
12 """ticket handling pages""" | 10 """ticket handling pages""" |
13 | 11 |
14 name = u'tickets_list' | 12 name = u'tickets' |
15 access = C.PAGES_ACCESS_PUBLIC | 13 access = C.PAGES_ACCESS_PUBLIC |
16 template = u"ticket/overview.html" | 14 template = u"ticket/overview.html" |
17 | 15 |
18 | 16 |
19 def parse_url(self, request): | 17 def parse_url(self, request): |
20 # check the service and node to use | 18 self.getPathArgs(request, ['service', 'node'], service='jid') |
21 try: | 19 data = self.getRData(request) |
22 service = self.nextPath(request) | |
23 node = self.nextPath(request) | |
24 except IndexError: | |
25 log.warning(_(u"missing service and node")) | |
26 self.pageError(request, C.HTTP_BAD_REQUEST) | |
27 | 20 |
28 if not service or service == u'@': | 21 service, node = data[u'service'], data[u'node'] |
29 service = u'' | 22 if node is None: |
30 | 23 self.pageRedirect(u"tickets_disco", request) |
31 if service: | 24 if node == u'@': |
32 try: | 25 node = data[u'node'] = u'' |
33 service = jid.JID(service) | |
34 except Exception: | |
35 log.warning(_(u"bad service entered: {}").format(service)) | |
36 self.pageError(request, C.HTTP_BAD_REQUEST) | |
37 | |
38 if not node or node == u'@': | |
39 node = u'' | |
40 | |
41 data = self.getRData(request) | |
42 data['service'] = service | |
43 data['node'] = node | |
44 | |
45 template_data = request.template_data | 26 template_data = request.template_data |
46 template_data[u'url_tickets_list'] = self.getPageByName('tickets_list').getURL(service.full(), node or u'@') | 27 template_data[u'url_tickets_list'] = self.getURL(service.full(), node or u'@') |
47 template_data[u'url_tickets_new'] = self.getSubPageURL(request, 'tickets_new') | 28 template_data[u'url_tickets_new'] = self.getSubPageURL(request, 'tickets_new') |
48 | 29 |
49 @defer.inlineCallbacks | 30 @defer.inlineCallbacks |
50 def prepare_render(self, request): | 31 def prepare_render(self, request): |
51 data = self.getRData(request) | 32 data = self.getRData(request) |