--- loncom/auth/lonlogin.pm 2021/11/03 01:04:02 1.193 +++ loncom/auth/lonlogin.pm 2022/05/27 01:36:08 1.197 @@ -1,7 +1,7 @@ # The LearningOnline Network # Login Screen # -# $Id: lonlogin.pm,v 1.193 2021/11/03 01:04:02 raeburn Exp $ +# $Id: lonlogin.pm,v 1.197 2022/05/27 01:36:08 raeburn Exp $ # # Copyright Michigan State University Board of Trustees # @@ -428,13 +428,14 @@ sub handler { if ($uextkey>2147483647) { $uextkey-=4294967296; } # -------------------------------------------------------- Store away log token - my ($tokenextras,$tokentype); + my ($tokenextras,$tokentype,$linkprot_for_login); my @names = ('role','symb','iptoken','ltoken','linkprot','linkkey'); foreach my $name (@names) { if ($env{'form.'.$name} ne '') { if ($name eq 'ltoken') { my %info = &Apache::lonnet::tmpget($env{'form.'.$name}); if ($info{'linkprot'}) { + $linkprot_for_login = $info{'linkprot'}; $tokenextras .= '&linkprot='.&escape($info{'linkprot'}); $tokentype = 'link'; last; @@ -442,6 +443,9 @@ sub handler { } else { $tokenextras .= '&'.$name.'='.&escape($env{'form.'.$name}); if (($name eq 'linkkey') || ($name eq 'linkprot')) { + if (($env{'form.retry'}) && (!$env{'form.ltoken'}) && ($name eq 'linkprot')) { + $linkprot_for_login = $env{'form.linkprot'}; + } $tokentype = 'link'; } } @@ -659,6 +663,7 @@ function toggleLClogin() { if (document.getElementById('LC_login_text')) { document.getElementById('LC_login_text').innerHTML = '$samlnonsso'; } + if ( document.client.uname ) { document.client.uname.focus(); } if (document.getElementById('LC_SSO_login')) { document.getElementById('LC_SSO_login').style.display = 'none'; } @@ -812,10 +817,14 @@ ENDSERVERFORM LFORM if ($showbanner) { + my $alttext = &Apache::loncommon::designparm('login.alttext_img',$domain); + if ($alttext eq '') { + $alttext = 'The Learning Online Network with CAPA'; + } $r->print(<
- The Learning Online Network with CAPA + $alttext
HEADER } @@ -858,7 +867,8 @@ HEADER } my $ssohref; if ($samlssoimg ne '') { - $ssohref = ''.$samlssoalt.''; + $ssohref = ''. + ''.$samlssoalt.''; } else { $ssohref = ''.$samlssotext.''; } @@ -892,6 +902,35 @@ ENDSAML delete($env{'form.ltoken'}); } } + my $in_frame_js; + if ($linkprot_for_login) { + my ($linkprotector,$linkproturi) = split(/:/,$linkprot_for_login,2); + if (($linkprotector =~ /^\d+(c|d)$/) && ($linkproturi =~ m{^/+tiny/+$LONCAPA::match_domain/+\w+$})) { + my $set_target; + if ($env{'form.retry'}) { + if ($linkproturi eq $env{'form.firsturl'}) { + $set_target = " document.server.target = '_self';"; + } + } else { + $set_target = < +// + +ENDJS + } + } $r->print(< @@ -913,7 +952,8 @@ ENDSAML ENDLOGIN $r->print('
'."\n"); if ($showmainlogo) { - $r->print(' '."\n"); + my $alttext = &Apache::loncommon::designparm('login.alttext_logo',$domain); + $r->print(' '."\n"); } $r->print(<
+$in_frame_js