--- loncom/auth/switchserver.pm 2022/06/30 21:04:13 1.61 +++ loncom/auth/switchserver.pm 2022/08/24 20:58:50 1.62 @@ -1,7 +1,7 @@ # The LearningOnline Network # Switch Servers Handler # -# $Id: switchserver.pm,v 1.61 2022/06/30 21:04:13 raeburn Exp $ +# $Id: switchserver.pm,v 1.62 2022/08/24 20:58:50 raeburn Exp $ # # Copyright Michigan State University Board of Trustees # @@ -54,7 +54,7 @@ sub init_env { } sub do_redirect { - my ($r,$url,$only_body,$extra_text) = @_; + my ($r,$url,$only_body,$extra_text,$write_to_opener) = @_; $r->send_http_header; my $delay = 0.5; if ($only_body && !$extra_text) { @@ -62,7 +62,7 @@ sub do_redirect { } my $start_page = &Apache::loncommon::start_page('Switching Server ...',undef, - {'redirect' => [$delay,$url], + {'redirect' => [$delay,$url,'',$write_to_opener], 'only_body' => $only_body,}); my $end_page = &Apache::loncommon::end_page(); $r->print($start_page.$extra_text.$end_page); @@ -102,7 +102,7 @@ sub handler { if (!defined($handle)) { return FORBIDDEN; } &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'}, - ['otherserver','role','origurl','symb']); + ['otherserver','role','origurl','symb','lcssowin']); my $switch_to=&Apache::lonnet::hostname($env{'form.otherserver'}); if (! $env{'form.otherserver'}) { @@ -291,7 +291,8 @@ sub handler { if ($env{'form.symb'}) { $info{'symb'} = $env{'form.symb'}; } - my $ssologoutscript = ''; + my $ssologoutscript = ''; + my $write_to_opener; if ($env{'request.sso.login'}) { $info{'sso.login'} = $env{'request.sso.login'}; if (defined($r->dir_config("lonSSOUserLogoutScriptFile_$info{domain}"))) { @@ -357,12 +358,18 @@ sub handler { $info{'lti.target'} = $env{'request.lti.target'}; } my $token = &Apache::lonnet::tmpput(\%info,$env{'form.otherserver'}); - my $url =$protocol.'://'.$switch_to.'/adm/login?'. - 'domain='.$env{'user.domain'}. - '&username='.$env{'user.name'}. - '&token='.$token; + my @args = ("domain=$env{'user.domain'}", + "username=$env{'user.name'}", + "token=$token"); + my $url = $protocol.'://'.$switch_to.'/adm/login?'; + if ($env{'form.lcssowin'}) { + $url .= join('&',@args); + $only_body = 1; + } else { + $url .= join('&',@args); + } # --------------------------------------------------------------- Screen Output - return &do_redirect($r, $url, $only_body, $ssologoutscript); + return &do_redirect($r, $url, $only_body, $ssologoutscript, $env{'form.lcssowin'}); } 1;