version 1.157, 2014/06/17 23:22:10
|
version 1.163, 2016/02/20 00:12:49
|
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 203 sub get_posted_cgi {
|
Line 202 sub get_posted_cgi {
|
$fname=''; |
$fname=''; |
$fmime=''; |
$fmime=''; |
} |
} |
|
if ($i<$#lines && $lines[$i+1]=~/^Content\-Type\:\s*([\w\-\/]+)/i) { |
|
# TODO: something with $1 ! |
|
$i++; |
|
} |
|
if ($i<$#lines && $lines[$i+1]=~/^Content\-transfer\-encoding\:\s*([\w\-\/]+)/i) { |
|
# TODO: something with $1 ! |
|
$i++; |
|
} |
$i++; |
$i++; |
} |
} |
} else { |
} else { |
Line 290 sub sso_login {
|
Line 297 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 317 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 332 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 374 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 455 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 579 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; |
Line 590 sub handler {
|
Line 613 sub handler {
|
return HTTP_NOT_ACCEPTABLE; |
return HTTP_NOT_ACCEPTABLE; |
} |
} |
} |
} |
|
} elsif (($handle =~ /^publicuser_\d+$/) && (&Apache::lonnet::is_portfolio_url($requrl))) { |
|
my $clientip = $r->get_remote_host(); |
|
if (&Apache::lonnet::allowed('bre',$requrl,undef,undef,$clientip) ne 'F') { |
|
$env{'user.error.msg'}="$requrl:bre:1:1:Access Denied"; |
|
return HTTP_NOT_ACCEPTABLE; |
|
} |
} else { |
} else { |
$env{'user.error.msg'}="$requrl:bre:1:1:Access Denied"; |
$env{'user.error.msg'}="$requrl:bre:1:1:Access Denied"; |
return HTTP_NOT_ACCEPTABLE; |
return HTTP_NOT_ACCEPTABLE; |
Line 728 sub handler {
|
Line 757 sub handler {
|
} |
} |
# ------------------------------------ See if this is a viewable portfolio file |
# ------------------------------------ See if this is a viewable portfolio file |
if (&Apache::lonnet::is_portfolio_url($requrl)) { |
if (&Apache::lonnet::is_portfolio_url($requrl)) { |
my $access=&Apache::lonnet::allowed('bre',$requrl); |
my $clientip = $r->get_remote_host(); |
|
my $access=&Apache::lonnet::allowed('bre',$requrl,undef,undef,$clientip); |
if ($access eq 'A') { |
if ($access eq 'A') { |
&Apache::restrictedaccess::setup_handler($r); |
&Apache::restrictedaccess::setup_handler($r); |
return OK; |
return OK; |