view src/pages/tickets/disco/page_meta.py @ 1100:5976dcd42591

pages (g): use server's connect method to connect instead of bridge, this way normal Libervia workflow is used, and session attributes are initialised.
author Goffi <goffi@goffi.org>
date Fri, 01 Jun 2018 18:31:29 +0200
parents 296bda6b7ed0
children cdd389ef97bc
line wrap: on
line source

#!/usr/bin/env python2.7
# -*- coding: utf-8 -*-

from libervia.server.constants import Const as C
from twisted.words.protocols.jabber import jid
from sat.core.log import getLogger
log = getLogger('pages/ticket')
"""ticket handling pages"""

name = u'tickets_disco'
access = C.PAGES_ACCESS_PUBLIC
template = u"ticket/discover.html"


def prepare_render(self, request):
    tickets_trackers_config = self.host.options['tickets_trackers_json']
    if tickets_trackers_config:
        trackers = request.template_data['tickets_trackers'] = []
        try:
            for tracker_data in tickets_trackers_config:
                service = tracker_data[u'service']
                node = tracker_data[u'node']
                name = tracker_data[u'name']
                url = self.getPageByName(u'tickets').getURL(service, node)
                trackers.append({u'name': name, u'url': url})
        except KeyError as e:
            log.warning(u"Missing field in tickets_trackers_json: {msg}".format(msg=e))
        except Exception as e:
            log.warning(u"Can't decode tickets trackers: {msg}".format(msg=e))

def on_data_post(self, request):
    jid_str = self.getPostedData(request, u'jid')
    try:
       jid_ = jid.JID(jid_str)
    except RuntimeError:
        self.pageError(request, C.HTTP_BAD_REQUEST)
    # for now we just use default node
    url = self.getPageByName(u'tickets').getURL(jid_.full(), u'@')
    self.HTTPRedirect(request, url)