--- loncom/auth/publiccheck.pm 2013/12/13 02:10:27 1.23 +++ loncom/auth/publiccheck.pm 2014/12/01 22:52:54 1.24 @@ -1,7 +1,7 @@ # The LearningOnline Network # Cookie Based Access Handler # -# $Id: publiccheck.pm,v 1.23 2013/12/13 02:10:27 raeburn Exp $ +# $Id: publiccheck.pm,v 1.24 2014/12/01 22:52:54 raeburn Exp $ # # Copyright Michigan State University Board of Trustees # @@ -70,7 +70,7 @@ sub handler { } elsif (&Apache::lonnet::is_portfolio_url($requrl)) { my (undef,$udom,$unum,$file_name,$group) = &Apache::lonnet::parse_portfolio_url($requrl); - my $access = &process_portfolio($udom,$unum,$file_name,$group); + my $access = &process_portfolio($r,$udom,$unum,$file_name,$group); if ($access) { &process_public($r,$requrl,$access); return OK; @@ -102,11 +102,12 @@ sub process_public { } sub process_portfolio { - my ($udom,$unum,$file_name,$group) = @_; + 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); my $access = ''; my $now = time; + my $clientip = $r->get_remote_host(); foreach my $key (keys(%{$access_controls{$file_name}})) { my ($num,$scope,$end,$start) = ($key =~ /^([^:]+):([a-z]+)_(\d*)_?(\d*)$/); if ($start > $now) { @@ -119,6 +120,16 @@ sub process_portfolio { $access = 'public'; last; } + if ($scope eq 'ip') { + 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'; }