From e841faf4a5e729aff8831ef72dab41adb51d6cf0 Mon Sep 17 00:00:00 2001 From: Simo Sorce Date: Fri, 12 Sep 2014 17:17:59 -0400 Subject: Allow deferred initialization of providers This fixes enabling a provider after the sever is started. Signed-off-by: Simo Sorce Reviewed-by: Patrick Uiterwijk --- ipsilon/providers/saml2/admin.py | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) (limited to 'ipsilon/providers/saml2') diff --git a/ipsilon/providers/saml2/admin.py b/ipsilon/providers/saml2/admin.py index 1c62cac..b8c8223 100755 --- a/ipsilon/providers/saml2/admin.py +++ b/ipsilon/providers/saml2/admin.py @@ -306,16 +306,20 @@ class AdminPage(Page): except Exception, e: # pylint: disable=broad-except self._debug("Failed to remove provider %s: %s" % (name, str(e))) - def mount(self, page): - self.menu = page.menu - self.url = '%s/%s' % (page.url, self.name) + def add_sps(self): if self.cfg.idp: for p in self.cfg.idp.get_providers(): try: sp = ServiceProvider(self.cfg, p) + self.del_sp(sp.name) self.add_sp(sp.name, sp) except Exception, e: # pylint: disable=broad-except self._debug("Failed to find provider %s: %s" % (p, str(e))) + + def mount(self, page): + self.menu = page.menu + self.url = '%s/%s' % (page.url, self.name) + self.add_sps() self.add_subtree('new', NewSPAdminPage(self._site, self)) page.add_subtree(self.name, self) -- cgit