Mercurial > libervia-web
view src/pages/g/page_meta.py @ 952:0f309eeef26d
Added robots.txt:
robots.txt is added currently in src/browser/public/robots.txt because that's what is served at root with current Pyjamas implementation, this should change when Pyjamas will be removed (for Libervia 0.8).
Current version uses "Allow" which is not recognized by all crawlers, but major ones should do.
author | Goffi <goffi@goffi.org> |
---|---|
date | Thu, 22 Jun 2017 09:09:02 +0200 |
parents | 43df2bf38787 |
children | 5cdd77190a3b |
line wrap: on
line source
#!/usr/bin/env python2.7 # -*- coding: utf-8 -*- from libervia.server.constants import Const as C from sat.core.i18n import _ from twisted.internet import defer from libervia.server import session_iface from sat.core.log import getLogger log = getLogger('pages/g') access = C.PAGES_ACCESS_PUBLIC template = u"invitation/welcome.html" @defer.inlineCallbacks def parse_url(self, request): """check invitation id in URL and start session if needed if a session already exists for an other guest/profile, it will be purged """ try: invitation_id = self.nextPath(request) except IndexError: self.pageError(request) sat_session, guest_session = self.host.getSessionData(request, session_iface.ISATSession, session_iface.ISATGuestSession) current_id = guest_session.id if current_id is not None and current_id != invitation_id: log.info(_(u'killing guest session [{old_id}] because it is connecting with an other ID [{new_id}]').format( old_id = current_id, new_id = invitation_id)) self.host.purgeSession(request) sat_session, guest_session = self.host.getSessionData(request, session_iface.ISATSession, session_iface.ISATGuestSession) current_id = None # FIXME: id non mis à zéro ici profile = None profile = sat_session.profile if profile is not None and current_id is None: log.info(_(u'killing current profile session [{profile}] because a guest id is used').format( profile = profile)) self.host.purgeSession(request) sat_session, guest_session = self.host.getSessionData(request, session_iface.ISATSession, session_iface.ISATGuestSession) profile = None if current_id is None: log.debug(_(u"checking invitation [{id}]").format(id=invitation_id)) try: data = yield self.host.bridge.invitationGet(invitation_id) except Exception: self.pageError(request, C.HTTP_UNAUTHORIZED) else: guest_session.id = invitation_id guest_session.data = data else: data = guest_session.data if profile is None: log.debug(_(u"connecting profile [{}]").format(profile)) # we need to connect the profile profile = data['guest_profile'] password = data['password'] try: yield self.host.bridge.connect(profile, password, {}) except Exception as e: log.warning(_(u"Can't connect profile: {msg}").format( msg=e)) # FIXME: no good error code correspond # maybe use a custom one? self.pageError(request, code=C.HTTP_SERVICE_UNAVAILABLE) log.info(_(u"guest session started, connected with profile [{profile}]".format( profile = profile))) sat_session.profile = profile # we copy data useful in templates template_data = request.template_data if u'name' in data: template_data[u'name'] = data[u'name'] if u'language' in data: template_data[u'locale'] = data[u'language'] def prepare_render(self, request): template_data = request.template_data guest_session = self.host.getSessionData(request, session_iface.ISATGuestSession) main_uri = guest_session.data.get('main_uri') template_data[u"include_url"] = self.getPagePathFromURI(main_uri)