X-Git-Url: http://git.cascardo.info/?a=blobdiff_plain;f=ipsilon%2Froot.py;h=6326436700256c342e97d211a84639855ff805e9;hb=93d4e52712767fe955f3a44a60a6c6f0f909423b;hp=30f6b438ce656c6903841b501f7a982e847c19ec;hpb=2fb8bff093e49d95ab25eb8343ebbb1091f6e7a6;p=cascardo%2Fipsilon.git diff --git a/ipsilon/root.py b/ipsilon/root.py old mode 100755 new mode 100644 index 30f6b43..6326436 --- a/ipsilon/root.py +++ b/ipsilon/root.py @@ -1,5 +1,3 @@ -#!/usr/bin/python -# # Copyright (C) 2013 Simo Sorce # # see file 'COPYING' for use and warranty information @@ -18,8 +16,18 @@ # along with this program. If not, see . from ipsilon.util.page import Page +from ipsilon.util import errors from ipsilon.login.common import Login from ipsilon.login.common import Logout +from ipsilon.admin.common import Admin +from ipsilon.providers.common import LoadProviders +from ipsilon.admin.loginstack import LoginStack +from ipsilon.admin.info import InfoPlugins +from ipsilon.admin.login import LoginPlugins +from ipsilon.admin.providers import ProviderPlugins +from ipsilon.rest.common import Rest +from ipsilon.rest.providers import RestProviderPlugins +import cherrypy sites = dict() @@ -27,15 +35,36 @@ sites = dict() class Root(Page): def __init__(self, site, template_env): - if not site in sites: + if site not in sites: sites[site] = dict() if template_env: sites[site]['template_env'] = template_env super(Root, self).__init__(sites[site]) + self.html_heads = dict() + + # set up error pages + cherrypy.config['error_page.400'] = errors.Error_400(self._site) + cherrypy.config['error_page.401'] = errors.Error_401(self._site) + cherrypy.config['error_page.404'] = errors.Error_404(self._site) + cherrypy.config['error_page.500'] = errors.Errors(self._site) # now set up the default login plugins self.login = Login(self._site) self.logout = Logout(self._site) + # set up idp providers now + LoadProviders(self, self._site) + + # after all plugins are setup we can instantiate the admin pages + self.admin = Admin(self._site, 'admin') + self.rest = Rest(self._site, 'rest') + self.stack = LoginStack(self._site, self.admin) + LoginPlugins(self._site, self.stack) + InfoPlugins(self._site, self.stack) + ProviderPlugins(self._site, self.admin) + RestProviderPlugins(self._site, self.rest) + def root(self): - return self._template('index.html', title='Root') + self.debug(self.html_heads) + return self._template('index.html', title='Ipsilon', + heads=self.html_heads)