version 1.157, 2014/06/17 23:22:10
|
version 1.159.2.2, 2016/08/05 20:27:18
|
Line 109 sub cleanup {
|
Line 109 sub cleanup {
|
my ($r)=@_; |
my ($r)=@_; |
if (! $r->is_initial_req()) { return DECLINED; } |
if (! $r->is_initial_req()) { return DECLINED; } |
&Apache::lonnet::save_cache(); |
&Apache::lonnet::save_cache(); |
&Apache::lontexconvert::jsMath_reset(); |
|
return OK; |
return OK; |
} |
} |
|
|
Line 290 sub sso_login {
|
Line 289 sub sso_login {
|
return undef; |
return undef; |
} |
} |
|
|
my ($user) = ($r->user =~ m/([a-zA-Z0-9_\-@.]*)/); |
my ($user) = ($r->user =~ m/^($match_username)$/); |
|
if ($user eq '') { |
|
return undef; |
|
} |
|
|
my $query = $r->args; |
my $query = $r->args; |
my %form; |
my %form; |
Line 307 sub sso_login {
|
Line 309 sub sso_login {
|
my %sessiondata; |
my %sessiondata; |
if ($form{'iptoken'}) { |
if ($form{'iptoken'}) { |
%sessiondata = &Apache::lonnet::tmpget($form{'iptoken'}); |
%sessiondata = &Apache::lonnet::tmpget($form{'iptoken'}); |
my $delete = &Apache::lonnet::tmpdel($form{'token'}); |
my $delete = &Apache::lonnet::tmpdel($form{'iptoken'}); |
|
unless ($sessiondata{'sessionserver'}) { |
|
delete($form{'iptoken'}); |
|
} |
} |
} |
|
|
my $domain = $r->dir_config('lonSSOUserDomain'); |
my $domain = $r->dir_config('lonSSOUserDomain'); |
Line 319 sub sso_login {
|
Line 324 sub sso_login {
|
&Apache::lonnet::logthis(" SSO authorized user $user "); |
&Apache::lonnet::logthis(" SSO authorized user $user "); |
my ($is_balancer,$otherserver,$hosthere); |
my ($is_balancer,$otherserver,$hosthere); |
if ($form{'iptoken'}) { |
if ($form{'iptoken'}) { |
if (($sessiondata{'domain'} eq $form{'udom'}) && |
if (($sessiondata{'domain'} eq $domain) && |
($sessiondata{'username'} eq $form{'uname'})) { |
($sessiondata{'username'} eq $user)) { |
$hosthere = 1; |
$hosthere = 1; |
} |
} |
} |
} |
Line 361 sub sso_login {
|
Line 366 sub sso_login {
|
'server' => $r->dir_config('lonHostID'), |
'server' => $r->dir_config('lonHostID'), |
'sso.login' => 1 |
'sso.login' => 1 |
); |
); |
foreach my $item ('role','symb') { |
foreach my $item ('role','symb','iptoken') { |
if (exists($form{$item})) { |
if (exists($form{$item})) { |
$info{$item} = $form{$item}; |
$info{$item} = $form{$item}; |
} |
} |
Line 442 sub handler {
|
Line 447 sub handler {
|
my ($is_balancer,$otherserver); |
my ($is_balancer,$otherserver); |
|
|
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{^/adm/help/}) || |
|
($requrl =~ m{^/res/$match_domain/$match_username/})) { |
$r->log_reason("Cookie not valid", $r->filename); |
$r->log_reason("Cookie not valid", $r->filename); |
} |
} |
} elsif ($handle ne '') { |
} elsif ($handle ne '') { |
Line 563 sub handler {
|
Line 571 sub handler {
|
if ($requrl !~ m{^/(?:adm|public|prtspool)/} |
if ($requrl !~ m{^/(?:adm|public|prtspool)/} |
|| $requrl =~ /^\/adm\/.*\/(smppg|bulletinboard)(\?|$ )/x) { |
|| $requrl =~ /^\/adm\/.*\/(smppg|bulletinboard)(\?|$ )/x) { |
my $access=&Apache::lonnet::allowed('bre',$requrl); |
my $access=&Apache::lonnet::allowed('bre',$requrl); |
|
if ($handle eq '') { |
|
unless ($access eq 'F') { |
|
if ($requrl =~ m{^/res/$match_domain/$match_username/}) { |
|
$r->log_reason("Cookie not valid", $r->filename); |
|
} |
|
} |
|
} |
if ($access eq '1') { |
if ($access eq '1') { |
$env{'user.error.msg'}="$requrl:bre:0:0:Choose Course"; |
$env{'user.error.msg'}="$requrl:bre:0:0:Choose Course"; |
return HTTP_NOT_ACCEPTABLE; |
return HTTP_NOT_ACCEPTABLE; |