--- loncom/auth/lonacc.pm 2006/06/30 02:58:38 1.82 +++ loncom/auth/lonacc.pm 2006/07/21 16:07:48 1.88 @@ -1,7 +1,7 @@ # The LearningOnline Network # Cookie Based Access Handler # -# $Id: lonacc.pm,v 1.82 2006/06/30 02:58:38 albertel Exp $ +# $Id: lonacc.pm,v 1.88 2006/07/21 16:07:48 albertel Exp $ # # Copyright Michigan State University Board of Trustees # @@ -35,8 +35,10 @@ use Apache::File; use Apache::lonnet; use Apache::loncommon(); use Apache::lonlocal; +use Apache::restrictedaccess(); use CGI::Cookie(); use Fcntl qw(:flock); +use LONCAPA; sub cleanup { my ($r)=@_; @@ -136,7 +138,27 @@ sub get_posted_cgi { } sub portfolio_access { + my ($r,$requrl) = @_; + my $access=&Apache::lonnet::allowed('bre',$requrl); + if ($access eq '2' || $access eq 'F') { + return OK; + } + my (undef,$udom,$unum,$file_name,$group) = &parse_portfolio_url($requrl); + my $result = &get_portfolio_access($udom,$unum,$file_name,$group); + &Apache::lonnet::logthis("got pa of $result"); + if ($result eq 'ok') { + return OK; + } elsif ($result =~ /^[^:]+:guest_/) { + &Apache::lonnet::logthis("doign pac $result"); + &passphrase_access_checker($r,$result,$requrl); + return OK; + } + return undef; +} + +sub get_portfolio_access { my ($udom,$unum,$file_name,$group) = @_; + my $current_perms = &Apache::lonnet::get_portfile_permissions($udom,$unum); my %access_controls = &Apache::lonnet::get_access_controls( $current_perms,$group,$file_name); @@ -172,14 +194,13 @@ sub portfolio_access { } if ($env{'user.name'} eq 'public' && $env{'user.domain'} eq 'public') { if ($guest) { - return 'guest:'.$guest; + return $guest; } } else { if (@domains > 0) { foreach my $domkey (@domains) { - my %content = &Apache::lonnet::parse_access_controls($$access_hash{$domkey}); - if (ref($content{'dom'}) eq 'ARRAY') { - if (grep(/^\Q$env{'user.domain'}\E$/,@{$content{'dom'}})) { + if (ref($access_hash->{$domkey}{'dom'}) eq 'ARRAY') { + if (grep(/^\Q$env{'user.domain'}\E$/,@{$access_hash->{$domkey}{'dom'}})) { return 'ok'; } } @@ -187,8 +208,7 @@ sub portfolio_access { } if (@users > 0) { foreach my $userkey (@users) { - my %content = &Apache::lonnet::parse_access_controls($$access_hash{$userkey}); - if (exists($content{'users'}{$env{'user.name'}.':'.$env{'user.domain'}})) { + if (exists($access_hash->{$userkey}{'users'}{$env{'user.name'}.':'.$env{'user.domain'}})) { return 'ok'; } } @@ -227,7 +247,7 @@ sub portfolio_access { return; } foreach my $key (@courses_and_groups) { - my %content = &Apache::lonnet::parse_access_controls($$access_hash{$key}); + my %content = %{$$access_hash{$key}}; my $cnum = $content{'number'}; my $cdom = $content{'domain'}; my $cid = $cdom.'_'.$cnum; @@ -247,7 +267,7 @@ sub portfolio_access { return 'ok'; } else { if (grep/^$sec$/,@sections) { - return 'ok' + return 'ok'; } } } @@ -272,13 +292,30 @@ sub portfolio_access { } } if ($guest) { - return 'guest:'.$guest; + return $guest; } } } return; } +sub passphrase_access_checker { + my ($r,$guestkey,$requrl) = @_; + my ($num,$scope,$end,$start) = ($guestkey =~ /^([^:]+):([a-z]+)_(\d*)_?(\d*)$/); + if ($scope eq 'guest') { + if (exists($env{'user.passphrase_access_'.$requrl})) { + if (($env{'user.passphrase_access_'.$requrl} == 0) || + ($env{'user.passphrase_access_'.$requrl} > time)) { + $env{'request.publicaccess'} = 1; + return 'ok'; + } + } + } + $r->set_handlers('PerlHandler'=> \&Apache::restrictedaccess::handler); + $r->content_type('perl-script'); + return; +} + sub course_group_datechecker { my ($dates,$now,$status) = @_; my ($start,$end) = split(/\./,$dates); @@ -303,6 +340,34 @@ sub course_group_datechecker { return; } +sub parse_portfolio_url { + my ($url) = @_; + + my ($type,$udom,$unum,$group,$file_name); + + if ($url =~ m-/+uploaded/([^/]+)/([^/]+)/portfolio(/.+)$-) { + $type = 1; + $udom = $1; + $unum = $2; + $file_name = $3; + } elsif ($url =~ m-/+uploaded/([^/]+)/([^/]+)/groups/([^/]+)/portfolio/(.+)$-) { + $type = 2; + $udom = $1; + $unum = $2; + $group = $3; + $file_name = $3.'/'.$4; + } + if (wantarray) { + return ($type,$udom,$unum,$file_name,$group); + } + return $type; +} + +sub is_portfolio_url { + my ($url) = @_; + return scalar(&parse_portfolio_url($url)); +} + sub handler { my $r = shift; my $requrl=$r->uri; @@ -365,23 +430,10 @@ sub handler { # ---------------------------------------------------------------- Check access my $now = time; - if ($requrl =~ m|/+uploaded/([^/]+)/([^/]+)/portfolio(/.+)$|) { - my $result = &portfolio_access($1,$2,$3); - if ($result eq 'ok') { - return OK; - } elsif ($result =~ /^guest:(\w+)$/) { - my $guestkey = $1; - #FIXME need to cause generation of an intermediate page - } - } elsif ($requrl =~ m|/+uploaded/([^/]+)/([^/]+)/groups/([^/]+)/portfolio/(.+)$|) { - my $result = &portfolio_access($1,$2,$3.'/'.$4,$3); - if ($result eq 'ok') { - return OK; - } elsif ($result =~ /^guest:(\w+)$/) { - my $guestkey = $1; - #FIXME need to cause generation of an intermediate page -} - } + if (&is_portfolio_url($requrl)) { + my $result = &portfolio_access($r,$requrl); + if (defined($result)) { return $result; } + } if ($requrl!~/^\/adm|public|prtspool\//) { my $access=&Apache::lonnet::allowed('bre',$requrl); if ($access eq '1') { @@ -472,7 +524,7 @@ sub handler { } else { $r->log_reason("Cookie $handle not valid", $r->filename); } - } + } # -------------------------------------------- See if this is a public resource if ($requrl=~m|^/public/| @@ -495,23 +547,11 @@ sub handler { return OK; } # ------------------------------------- See if this is a viewable portfolio file - if ($requrl =~ m|/+uploaded/([^/]+)/([^/]+)/portfolio(/.+)$|) { - my $result = &portfolio_access($1,$2,$3); - if ($result eq 'ok') { - return OK; - } elsif ($result =~ /^guest:(\w+)$/) { - my $guestkey = $1; - #FIXME need to cause generation of an intermediate page - } - } elsif ($requrl =~ m|/+uploaded/([^/]+)/([^/]+)/groups/([^/]+)/portfolio/(.+)$|) { - my $result = &portfolio_access($1,$2,$3.'/'.$4,$3); - if ($result eq 'ok') { - return OK; - } elsif ($result =~ /^guest:(\w+)$/) { - my $guestkey = $1; - #FIXME need to cause generation of an intermediate page - } + if (&is_portfolio_url($requrl)) { + my $result = &portfolio_access($r,$requrl); + if (defined($result)) { return $result; } } + # -------------------------------------------------------------- Not authorized $requrl=~/\.(\w+)$/; # if ((&Apache::loncommon::fileembstyle($1) eq 'ssi') ||