--- loncom/auth/publiccheck.pm 2006/04/05 22:34:18 1.1 +++ loncom/auth/publiccheck.pm 2024/08/25 00:30:45 1.24.2.3.2.1 @@ -1,7 +1,7 @@ # The LearningOnline Network # Cookie Based Access Handler # -# $Id: publiccheck.pm,v 1.1 2006/04/05 22:34:18 albertel Exp $ +# $Id: publiccheck.pm,v 1.24.2.3.2.1 2024/08/25 00:30:45 raeburn Exp $ # # Copyright Michigan State University Board of Trustees # @@ -31,50 +31,117 @@ package Apache::publiccheck; use strict; use Apache::Constants qw(:common :http :methods); -use Apache::File; use Apache::lonnet; use Apache::loncommon(); use Apache::lonlocal; -use CGI::Cookie(); use Fcntl qw(:flock); +use Apache::lonacc(); +use LONCAPA(); sub handler { my $r = shift; + my $requrl=$r->uri; - my %cookies=CGI::Cookie->parse($r->header_in('Cookie')); - my $lonid=$cookies{'lonID'}; - if ($lonid) { - my $handle=$lonid->value; - $handle=~s/\W//g; + + if (&Apache::lonnet::is_domainimage($requrl)) { + return OK; + } + + if ($requrl =~ m{^/res/adm/pages/[^/]+\.(gif|png)$}) { + return OK; + } + + my $handle = &Apache::lonnet::check_for_valid_session($r); + if ($handle ne '') { my $lonidsdir=$r->dir_config('lonIDsDir'); - if ((-e "$lonidsdir/$handle.id") && ($handle ne '')) { - &Apache::lonnet::transfer_profile_to_env($lonidsdir,$handle); - if ($env{'user.name'} ne 'public' - && $env{'user.domain'} ne 'public') { - return OK; - } + &Apache::lonnet::transfer_profile_to_env($lonidsdir,$handle); + if ($env{'user.name'} ne 'public' + && $env{'user.domain'} ne 'public') { + return OK; } } if ($requrl=~m|^/public/| - || (&Apache::lonnet::metadata($requrl,'copyright') eq 'public')) { - &Apache::lonnet::logthis('Granting public access: '.$requrl); - if ($env{'user.name'} ne 'public' - && $env{'user.domain'} ne 'public') { - my $cookie= - &Apache::lonauth::success($r,'public','public','public'); - my $lonidsdir=$r->dir_config('lonIDsDir'); - &Apache::lonnet::transfer_profile_to_env($lonidsdir,$cookie); - $r->header_out('Set-cookie',"lonID=$cookie; path=/"); - } - &Apache::loncommon::get_posted_cgi($r); - $env{'request.state'} = "published"; - $env{'request.publicaccess'} = 1; - $env{'request.filename'} = $r->filename; + || $requrl=~m|^/adm/help/.*\.hlp$| + || $requrl=~m|^/adm/[^/]+/[^/]+/aboutme/portfolio$| + || (&Apache::lonnet::metadata($requrl,'copyright') eq 'public') + || $requrl=~m|^/adm/blockingstatus/.*$|) { + &process_public($r,$requrl); return OK; + } elsif (&Apache::lonnet::is_portfolio_url($requrl)) { + my (undef,$udom,$unum,$file_name,$group) = + &Apache::lonnet::parse_portfolio_url($requrl); + my $access = &process_portfolio($r,$udom,$unum,$file_name,$group); + if ($access) { + &process_public($r,$requrl,$access); + return OK; + } + } elsif ($requrl eq '/adm/restrictedaccess') { + &process_public($r,$requrl); + return OK; + } elsif ($requrl eq '/adm/blockedaccess') { + &process_public($r,$requrl); + return OK; } return DECLINED; } +sub process_public { + my ($r,$requrl,$access) = @_; + &Apache::lonnet::logthis('Granting public access: '.$requrl); + if ($env{'user.name'} ne 'public' && $env{'user.domain'} ne 'public') { + my $cookie=&Apache::lonauth::success($r,'public','public','public'); + my $lonidsdir=$r->dir_config('lonIDsDir'); + &Apache::lonnet::transfer_profile_to_env($lonidsdir,$cookie); + $r->err_header_out('Set-cookie',"lonPubID=$cookie; path=/; HttpOnly"); + } + &Apache::lonacc::get_posted_cgi($r); + $env{'request.state'} = "published"; + $env{'request.publicaccess'} = 1; + $env{'request.filename'} = $r->filename; + return; +} + +sub process_portfolio { + my ($r,$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); + return unless (ref($access_controls{$file_name}) eq 'HASH'); + my $access = ''; + my $now = time; + my $clientip = &Apache::lonnet::get_requestor_ip($r); + my $portaccess = &Apache::lonnet::usertools_access($unum,$udom,'portaccess',undef,'tools'); + foreach my $key (keys(%{$access_controls{$file_name}})) { + my ($num,$scope,$end,$start) = ($key =~ /^([^:]+):([a-z]+)_(\d*)_?(\d*)$/); + if (!$portaccess) { + next unless ($scope eq 'ip'); + } + if ($start > $now) { + next; + } + if ($end && $end<$now) { + next; + } + if ($scope eq 'public') { + $access = 'public'; + last; + } + if (($scope eq 'ip') || ($scope eq 'userip')) { + if (ref($access_controls{$file_name}{$key}) eq 'HASH') { + if (ref($access_controls{$file_name}{$key}{'ip'}) eq 'ARRAY') { + if (&Apache::loncommon::check_ip_acc(join(',',@{$access_controls{$file_name}{$key}{'ip'}}),$clientip)) { + $access = 'ip'; + last; + } + } + } + } + if ($scope eq 'guest') { + $access = 'guest'; + } + } + return $access; +} + 1; __END__