--- loncom/interface/lontiny.pm 2024/02/10 14:24:46 1.8.2.6 +++ loncom/interface/lontiny.pm 2024/02/09 20:08:16 1.21 @@ -2,7 +2,7 @@ # Extract domain, courseID, and symb from a shortened URL, # and switch role to a role in designated course. # -# $Id: lontiny.pm,v 1.8.2.6 2024/02/10 14:24:46 raeburn Exp $ +# $Id: lontiny.pm,v 1.21 2024/02/09 20:08:16 raeburn Exp $ # # Copyright Michigan State University Board of Trustees # @@ -440,48 +440,35 @@ sub launch_check { } } } else { - unless ($currdeeplinklogin eq $linkuri) { + if (($currdeeplinklogin ne $linkuri) || + (($prevlaunch ne '') && ($currdeeplinklogin ne $prevlaunch))) { if (($linkprotector) || ($linkkey ne '')) { - $newlauncher = 1; - } - } - if ($linkprotector) { - &Apache::lonnet::appenv({'request.linkprot' => $linkprotector.':'.$linkproturi}); - } elsif ($env{'request.linkprot'}) { - &Apache::lonnet::delenv('request.linkprot'); - } - if ($linkkey ne '') { - &Apache::lonnet::appenv({'request.linkkey' => $linkkey}); - } elsif ($env{'request.linkkey'} ne '') { - &Apache::lonnet::delenv('request.linkkey'); - } - if (($linkprotector) || ($linkkey ne '')) { - if ($linkprotexit ne $env{'request.linkprotexit'}) { + if ($linkprotector) { + &Apache::lonnet::appenv({'request.linkprot' => $linkprotector.':'.$linkproturi}); + } elsif ($env{'request.linkprot'}) { + &Apache::lonnet::delenv('request.linkprot'); + } if ($linkprotexit) { &Apache::lonnet::appenv({'request.linkprotexit' => $linkprotexit}); } elsif ($env{'request.linkprotexit'}) { &Apache::lonnet::delenv('request.linkprotexit'); } - } - if ($linkprotpbid ne $env{'request.linkprotpbid'}) { if ($linkprotpbid) { &Apache::lonnet::appenv({'request.linkprotpbid' => $linkprotpbid}); } elsif ($env{'request.linkprotpbid'}) { &Apache::lonnet::delenv('request.linkprotpbid'); } - } - if ($linkprotpburl ne $env{'request.linkprotpburl'}) { if ($linkprotpburl) { &Apache::lonnet::appenv({'request.linkprotpburl' => $linkprotpburl}); } elsif ($env{'request.linkprotpburl'}) { &Apache::lonnet::delenv('request.linkprotpburl'); } - } - } elsif ($prevlaunch) { - foreach my $requestkey ('linkprotpbid','linkprotpburl','linkprotexit') { - if ($env{"request.$requestkey"}) { - &Apache::lonnet::delenv("request.$requestkey"); + if ($linkkey ne '') { + &Apache::lonnet::appenv({'request.linkkey' => $linkkey}); + } elsif ($env{'request.linkkey'} ne '') { + &Apache::lonnet::delenv('request.linkkey'); } + $newlauncher = 1; } } &Apache::lonnet::appenv({'request.deeplink.login' => $linkuri});