version 1.191, 2021/06/22 16:56:35
|
version 1.196, 2021/10/25 15:26:27
|
Line 305 sub sso_login {
|
Line 305 sub sso_login {
|
my $query = $r->args; |
my $query = $r->args; |
my %form; |
my %form; |
if ($query) { |
if ($query) { |
my @items = ('role','symb','iptoken','origurl'); |
my @items = ('role','symb','iptoken','origurl','ltoken','linkkey'); |
&Apache::loncommon::get_unprocessed_cgi($query,\@items); |
&Apache::loncommon::get_unprocessed_cgi($query,\@items); |
foreach my $item (@items) { |
foreach my $item (@items) { |
if (defined($env{'form.'.$item})) { |
if (defined($env{'form.'.$item})) { |
Line 323 sub sso_login {
|
Line 323 sub sso_login {
|
} |
} |
} |
} |
|
|
|
my ($linkprot,$linkkey); |
|
if ($form{'ltoken'}) { |
|
my %link_info = &Apache::lonnet::tmpget($form{'ltoken'}); |
|
$linkprot = $link_info{'linkprot'}; |
|
my $delete = &Apache::lonnet::tmpdel($form{'ltoken'}); |
|
} |
|
if ($form{'linkkey'} ne '') { |
|
$linkkey = $form{'linkkey'}; |
|
} |
|
|
my $domain = $r->dir_config('lonSSOUserDomain'); |
my $domain = $r->dir_config('lonSSOUserDomain'); |
if ($domain eq '') { |
if ($domain eq '') { |
$domain = $r->dir_config('lonDefDomain'); |
$domain = $r->dir_config('lonDefDomain'); |
Line 372 sub sso_login {
|
Line 382 sub sso_login {
|
$env{'form.origurl'} = $r->uri; |
$env{'form.origurl'} = $r->uri; |
} |
} |
} |
} |
|
if (($r->uri eq '/adm/sso') && ($form{'origurl'} =~ m{^/+tiny/+$match_domain/+\w+$})) { |
|
$env{'request.deeplink.login'} = $form{'origurl'}; |
|
} elsif ($r->uri =~ m{^/+tiny/+$match_domain/+\w+$}) { |
|
$env{'request.deeplink.login'} = $r->uri; |
|
} |
|
if ($env{'request.deeplink.login'}) { |
|
if ($linkprot) { |
|
$env{'request.linkprot'} = $linkprot); |
|
} elsif ($linkkey ne '') { |
|
$env{'request.linkkey'} = $linkkey); |
|
} |
|
} |
$env{'request.sso.login'} = 1; |
$env{'request.sso.login'} = 1; |
if (defined($r->dir_config("lonSSOReloginServer"))) { |
if (defined($r->dir_config("lonSSOReloginServer"))) { |
$env{'request.sso.reloginserver'} = |
$env{'request.sso.reloginserver'} = |
Line 403 sub sso_login {
|
Line 425 sub sso_login {
|
$info{'origurl'} = $r->uri; |
$info{'origurl'} = $r->uri; |
} |
} |
} |
} |
|
if (($r->uri eq '/adm/sso') && ($form{'origurl'} =~ m{^/+tiny/+$match_domain/+\w+$})) { |
|
$info{'deeplink.login'} = $form{'origurl'}; |
|
} elsif ($r->uri =~ m{^/+tiny/+$match_domain/+\w+$}) { |
|
$info{'deeplink.login'} = $r->uri; |
|
} |
|
if ($info{'deeplink.login'}) { |
|
if ($linkprot) { |
|
$info{'linkprot'} = $linkprot; |
|
} elsif ($linkkey ne '') { |
|
$info{'linkkey'} = $linkkey; |
|
} |
|
} |
if ($r->dir_config("ssodirecturl") == 1) { |
if ($r->dir_config("ssodirecturl") == 1) { |
$info{'origurl'} = $r->uri; |
$info{'origurl'} = $r->uri; |
} |
} |
Line 479 sub handler {
|
Line 513 sub handler {
|
if ($handle eq '') { |
if ($handle eq '') { |
unless ((($requrl eq '/adm/switchserver') && (!$r->is_initial_req())) || |
unless ((($requrl eq '/adm/switchserver') && (!$r->is_initial_req())) || |
($requrl =~ m{^/public/$match_domain/$match_courseid/syllabus}) || |
($requrl =~ m{^/public/$match_domain/$match_courseid/syllabus}) || |
($requrl =~ m{^/adm/help/}) || |
($requrl =~ m{^/adm/help/}) || ($requrl eq '/adm/sso') || |
($requrl =~ m{^/res/$match_domain/$match_username/})) { |
($requrl =~ m{^/res/$match_domain/$match_username/})) { |
$r->log_reason("Cookie not valid", $r->filename); |
$r->log_reason("Cookie not valid", $r->filename); |
} |
} |
Line 673 sub handler {
|
Line 707 sub handler {
|
if ((!$env{'request.role.adv'}) && ($env{'acc.randomout'}) && |
if ((!$env{'request.role.adv'}) && ($env{'acc.randomout'}) && |
($env{'acc.randomout'}=~/\&\Q$poss_symb\E\&/)) { |
($env{'acc.randomout'}=~/\&\Q$poss_symb\E\&/)) { |
undef($poss_symb); |
undef($poss_symb); |
|
} elsif ((!$env{'request.role.adv'}) && ($env{'acc.deeplinkout'}) && |
|
($env{'acc.deeplinkout'}=~/\&\Q$poss_symb\E\&/)) { |
|
undef($poss_symb); |
} |
} |
} |
} |
} |
} |
Line 682 sub handler {
|
Line 719 sub handler {
|
$access=&Apache::lonnet::allowed('bre',$requrl,'','','','',1); |
$access=&Apache::lonnet::allowed('bre',$requrl,'','','','',1); |
} |
} |
} else { |
} else { |
$access=&Apache::lonnet::allowed('bre',$requrl); |
my $nodeeplinkcheck; |
|
if (($check_access) && ($requrl =~ /\.(sequence|page)$/)) { |
|
unless ($env{'form.navmap'}) { |
|
if ($r->args ne '') { |
|
&Apache::loncommon::get_unprocessed_cgi($r->args,['navmap']); |
|
unless ($env{'form.navmap'}) { |
|
$nodeeplinkcheck = 1; |
|
} |
|
} |
|
} |
|
} |
|
$access=&Apache::lonnet::allowed('bre',$requrl,'','','','','',$nodeeplinkcheck); |
} |
} |
} |
} |
if ($check_block) { |
if ($check_block) { |