Skip to content

Commit 1acc641

Browse files
committedSep 9, 2011
encryptLogin should not trump showMessageOnLogin. Fixes bug #12245.
1 parent d38992c commit 1acc641

File tree

2 files changed

+20
-13
lines changed

2 files changed

+20
-13
lines changed
 

‎docs/changelog/7.x.x.txt

+1
Original file line numberDiff line numberDiff line change
@@ -10,6 +10,7 @@
1010
- fixed #12246: Layout inherits mobileStyleTemplateId and mobileTemplateId from parent Layouts
1111
- fixed #12246: added extra_www_add_properties as properties fix-up hook in child for www_add
1212
- fixed #12231: Thingy reindex fails on upgrade
13+
- fixed #12245: Encrypt Login and Display Message on Login conflict
1314

1415
7.10.22
1516
- rfe #12223: Add date type to content profiling (metadata)

‎lib/WebGUI/Auth.pm

+19-13
Original file line numberDiff line numberDiff line change
@@ -32,6 +32,7 @@ use WebGUI::Workflow::Instance;
3232
use WebGUI::Shop::AddressBook;
3333
use WebGUI::Inbox;
3434
use WebGUI::Friends;
35+
use URI;
3536

3637
# Profile field name for the number of times the showMessageOnLogin has been
3738
# seen.
@@ -894,12 +895,6 @@ sub login {
894895
$u->karma($self->session->setting->get("karmaPerLogin"),"Login","Just for logging in.") if ($self->session->setting->get("useKarma"));
895896
$self->_logLogin($uid,"success");
896897

897-
if ($self->session->setting->get('encryptLogin')) {
898-
my $currentUrl = $self->session->url->page(undef,1);
899-
$currentUrl =~ s/^https:/http:/;
900-
$self->session->http->setRedirect($currentUrl);
901-
}
902-
903898
# Run on login
904899
my $command = $self->session->config->get("runOnLogin");
905900
if ($command ne "") {
@@ -927,6 +922,11 @@ sub login {
927922
$self->session->http->setRedirect($self->session->setting->get("redirectAfterLoginUrl"));
928923
$self->session->scratch->delete("redirectAfterLogin");
929924
}
925+
elsif ($self->session->setting->get('encryptLogin')) {
926+
my $currentUrl = $self->session->url->page(undef,1);
927+
$currentUrl =~ s/^https:/http:/;
928+
$self->session->http->setRedirect($currentUrl);
929+
}
930930

931931
# Get open version tag. This is needed if we want
932932
# to reclaim a version right after login (singlePerUser and siteWide mode)
@@ -1100,20 +1100,26 @@ sub showMessageOnLogin {
11001100

11011101
# Add the link to continue
11021102
my $session = $self->session;
1103-
$session->log->warn("returnUrl: >".$self->session->form->get( 'returnUrl' )."<");
1104-
$session->log->warn("redirectAfterLoginUrl: >".$self->session->form->get( 'returnUrl' )."<");
1105-
my $redirectUrl = $self->session->form->get( 'returnUrl' )
1106-
|| $self->session->setting->get("redirectAfterLoginUrl")
1107-
|| $self->session->scratch->get( 'redirectAfterLogin' )
1108-
|| $self->session->url->getBackToSiteURL
1103+
my $redirectUrl = $session->form->get( 'returnUrl' )
1104+
|| $session->setting->get("redirectAfterLoginUrl")
1105+
|| $session->scratch->get( 'redirectAfterLogin' )
1106+
|| $session->url->getBackToSiteURL
11091107
;
11101108

1109+
if ($session->setting->get('encryptLogin') && ( ! $redirectUrl =~ /^http/)) {
1110+
##A scheme-less URL has been supplied. We need to make it an absolute one
1111+
##with a non-encrypted scheme. Otherwise the user will stay in SSL mode.
1112+
##We assume that the user put the gateway URL into their URL.
1113+
my $uri = URI->new_abs($redirectUrl, $session->url->getSiteURL);
1114+
$uri->scheme('http');
1115+
$redirectUrl = $uri->as_string;
1116+
}
11111117
$output .= '<p><a href="' . $redirectUrl . '">' . $i18n->get( 'showMessageOnLogin return' )
11121118
. '</a></p>'
11131119
;
11141120

11151121
# No matter what, we won't be redirecting after this
1116-
$self->session->scratch->delete( 'redirectAfterLogin' );
1122+
$session->scratch->delete( 'redirectAfterLogin' );
11171123

11181124
return $output;
11191125
}

0 commit comments

Comments
 (0)
Please sign in to comment.