view src/pages/g/page_meta.py @ 962:c7fba7709d05

Pages: various improvments: - automatic confirmation message on data post can now be avoided by using the C.POST_NO_CONFIRM flag - new tailing_slash page variable can be used to force a trailing slash at the end of the URL (by redirecting if necessary) - LiberviaPage now has a url attribute with the its relative path - new redirection methods: - getPageRedirectURL: generate and URL which will redirect to current page (or somewhere else), mainly useful for login - HTTPRedirect: stop workflow and do a HTTP redirection - redirectOrContinue: redirect a page if redirect arguments is present (usually redirect_url), else continue workflow - profile access now redirect to login page if registration is allowed.
author Goffi <goffi@goffi.org>
date Fri, 27 Oct 2017 18:43:16 +0200
parents 5cdd77190a3b
children 01e95ec9df9e
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
    template_data['norobots'] = True
    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)