Mercurial > libervia-web
view src/pages/chat/select/page_meta.py @ 1059:d127a85b2fee
pages: don't log error anymore when empty page_meta.py are used
author | Goffi <goffi@goffi.org> |
---|---|
date | Tue, 30 Jan 2018 08:15:05 +0100 |
parents | ded41172dcb5 |
children | cdd389ef97bc |
line wrap: on
line source
#!/usr/bin/env python2.7 # -*- coding: utf-8 -*- from sat.core.i18n import _ from libervia.server.constants import Const as C from twisted.internet import defer from twisted.words.protocols.jabber import jid from sat.tools.common import data_objects from sat.core.log import getLogger log = getLogger('pages/chat_select') name = u'chat_select' access = C.PAGES_ACCESS_PROFILE template = u"chat/select.html" @defer.inlineCallbacks def prepare_render(self, request): profile = self.getProfile(request) template_data = request.template_data rooms = template_data['rooms'] = [] bookmarks = yield self.host.bridgeCall('bookmarksList', 'muc', 'all', profile) for bm_values in bookmarks.values(): for room_jid, room_data in bm_values.iteritems(): url = self.getPageByName(u'chat').getURL(room_jid) rooms.append(data_objects.Room(room_jid, name=room_data.get('name'), url=url)) rooms.sort(key=lambda r: r.name) @defer.inlineCallbacks def on_data_post(self, request): jid_ = self.getPostedData(request, u'jid') if u'@' not in jid_: profile = self.getProfile(request) service = yield self.host.bridgeCall('mucGetService', '', profile) if service: muc_jid = jid.JID(service) muc_jid.user = jid_ jid_ = muc_jid.full() else: log.warning(_(u"Invalid jid received: {jid}".format(jid=jid_))) defer.returnValue(C.POST_NO_CONFIRM) url = self.getPageByName(u'chat').getURL(jid_) self.HTTPRedirect(request, url)