Mercurial > libervia-web
view libervia/pages/register/page_meta.py @ 1128:6414fd795df4
server, pages: multi-sites refactoring:
Libervia is now handling external sites (i.e. other sites than Libervia official site).
The external site are declared in sites_path_public_dict (in [DEFAULT] section) which is read by template engine, then they are linked to virtual host with vhosts_dict (linking host name to site name) in [libervia] section.
Sites are only instanced once, so adding an alias is just a matter of mapping the alias host name in vhosts_dict with the same site name.
menu_json and url_redirections_dict can now accept keys named after site name, which will be linked to the data for the site. Data for default site can still be keyed at first level.
Libervia official pages are added to external site (if pages are not overriden), allowing to call pages of the framework and to have facilities like login handling.
Deprecated url_redirections_profile option has been removed.
author | Goffi <goffi@goffi.org> |
---|---|
date | Fri, 14 Sep 2018 21:41:28 +0200 |
parents | 28e3eb3bb217 |
children | 29eb15062416 |
line wrap: on
line source
#!/usr/bin/env python2.7 # -*- coding: utf-8 -*- from libervia.server.constants import Const as C from libervia.server import session_iface from twisted.internet import defer from sat.core.log import getLogger log = getLogger("pages/register") """SàT account registration page""" name = u"register" access = C.PAGES_ACCESS_PUBLIC template = u"login/register.html" def prepare_render(self, request): profile = self.getProfile(request) if profile is not None: self.pageRedirect("/login/logged", request) template_data = request.template_data template_data["login_url"] = self.getPageByName("login").url template_data["S_C"] = C # we need server constants in template # login error message session_data = self.host.getSessionData(request, session_iface.ISATSession) login_error = session_data.popPageData(self, "login_error") if login_error is not None: template_data["login_error"] = login_error # if fields were already filled, we reuse them for k in (u"login", u"email", u"password"): template_data[k] = session_data.popPageData(self, k) @defer.inlineCallbacks def on_data_post(self, request): type_ = self.getPostedData(request, u"type") if type_ == u"register": login, email, password = self.getPostedData( request, (u"login", u"email", u"password") ) status = yield self.host.registerNewAccount(request, login, password, email) session_data = self.host.getSessionData(request, session_iface.ISATSession) if status == C.REGISTRATION_SUCCEED: # we prefill login field for login page session_data.setPageData(self.getPageByName(u"login"), u"login", login) # if we have a redirect_url we follow it self.redirectOrContinue(request) # else we redirect to login page self.HTTPRedirect(request, self.getPageByName(u"login").url) else: session_data.setPageData(self, u"login_error", status) l = locals() for k in (u"login", u"email", u"password"): # we save fields so user doesn't have to enter them again session_data.setPageData(self, k, l[k]) defer.returnValue(C.POST_NO_CONFIRM) else: self.pageError(request, C.HTTP_BAD_REQUEST)