From: Patrick Uiterwijk Date: Tue, 3 Mar 2015 03:39:05 +0000 (+0100) Subject: Fix transaction ID passing for failed authentication X-Git-Tag: v0.5.0~36 X-Git-Url: http://git.cascardo.info/?p=cascardo%2Fipsilon.git;a=commitdiff_plain;h=06b387bcc632a8db9e812c9069247b10fe2b9695 Fix transaction ID passing for failed authentication Signed-off-by: Patrick Uiterwijk Reviewed-by: Simo Sorce --- diff --git a/ipsilon/login/common.py b/ipsilon/login/common.py index 4b715f3..60f6df1 100644 --- a/ipsilon/login/common.py +++ b/ipsilon/login/common.py @@ -37,9 +37,12 @@ class LoginManagerBase(PluginConfig, PluginObject): self.path = '/' self.info = None - def redirect_to_path(self, path): + def redirect_to_path(self, path, trans=None): base = cherrypy.config.get('base.mount', "") - raise cherrypy.HTTPRedirect('%s/login/%s' % (base, path)) + url = '%s/login/%s' % (base, path) + if trans: + url += '?%s' % trans.get_GET_arg() + raise cherrypy.HTTPRedirect(url) def auth_successful(self, trans, username, auth_type=None, userdata=None): session = UserSession() @@ -100,7 +103,7 @@ class LoginManagerBase(PluginConfig, PluginObject): # try with next module next_login = self.next_login() if next_login: - return self.redirect_to_path(next_login.path) + return self.redirect_to_path(next_login.path, trans) # return to the caller if any session = UserSession()